TL;博士
有没有人有在 Ubuntu Server 20.04 下设置动态 IPv4 和静态 IPv6的有效网络计划配置?
什么有效
/etc/netplan/50-cloud-init.yaml
我的提供商 (OVH) 为我提供了一个开箱即用的具有此配置的服务器:
# This file is generated from information provided by the datasource. Changes
# to it will not persist across an instance reboot. To disable cloud-init's
# network configuration capabilities, write a file
# /etc/cloud/cloud.cfg.d/99-disable-network-config.cfg with the following:
# network: {config: disabled}
network:
version: 2
ethernets:
ens3:
dhcp4: true
match:
macaddress: xx:yy:zz:aa:bb:cc
mtu: 1500
set-name: ens3
所以服务器正在通过 DHCP 获取 IPv4 地址。一切都在这里工作。
问题
但是,他们还提供了 netplan 配置中不存在的静态 IPv6(从该服务器的 Web 控制台管理中找到)。
我尝试手动添加它,使用如下代码段:
network:
version: 2
ethernets:
ens3:
dhcp6: false
match:
name: ens3
addresses:
- "dead:beef:404:200::cafe/128"
gateway6: "dead:beef:404:200::1"
但没有任何效果:如果 IPv4 有效,我就没有 IPv6,如果我获得 IPv6,它会撤销我的 IPv4,我将无法访问服务器。
尝试
/etc/netplan/60-test-askubuntu.yaml
在使用以下命令重命名所有其他文件后,我刚刚尝试了这个确切的配置.yaml.bak
:
network:
version: 2
ethernets:
ens3:
dhcp6: false
addresses:
- "2001:41d0:206:cd1d::6153/128"
gateway6: "2001:41d0:206:cd1d::1"
dhcp4: true
mtu: 1500
结果:IPv4 仍在工作,但我猜当 DHCP 保释到期时它会失败。IPv6 地址已设置,但未设置网关,因此我无法 ping6 IPv6 地址:
user@server:/etc/netplan$ ip a
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1000
link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
inet 127.0.0.1/8 scope host lo
valid_lft forever preferred_lft forever
inet6 ::1/128 scope host
valid_lft forever preferred_lft forever
2: ens3: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc fq_codel state UP group default qlen 1000
link/ether fa:16:3e:23:28:1f brd ff:ff:ff:ff:ff:ff
inet 51.210.xx.yy/32 scope global dynamic ens3
valid_lft 86396sec preferred_lft 86396sec
inet6 2001:41d0:206:cd1d::6153/128 scope global
valid_lft forever preferred_lft forever
inet6 fe80::f816:3eff:fe23:281f/64 scope link
valid_lft forever preferred_lft forever
user@server:/etc/netplan$ ip route
default via 51.210.8.1 dev ens3 proto dhcp src 51.210.xx.yy metric 100
51.210.8.1 dev ens3 proto dhcp scope link src 51.210.xx.yy metric 100
user@server:/etc/netplan$ ping google.com
PING google.com (172.217.22.142) 56(84) bytes of data.
64 bytes from par21s12-in-f14.1e100.net (172.217.22.142): icmp_seq=1 ttl=51 time=6.16 ms
64 bytes from par21s12-in-f14.1e100.net (172.217.22.142): icmp_seq=2 ttl=51 time=6.19 ms
^C
--- google.com ping statistics ---
2 packets transmitted, 2 received, 0% packet loss, time 1001ms
rtt min/avg/max/mdev = 6.161/6.177/6.194/0.016 ms
user@server:/etc/netplan$ ping6 google.com
ping6: connect: Network is unreachable
user@server:/etc/netplan$ ip route
default via 51.210.8.1 dev ens3 proto dhcp src 51.210.xx.yy metric 100
51.210.8.1 dev ens3 proto dhcp scope link src 51.210.xx.yy metric 100
user@server:/etc/netplan$ ip -6 route
::1 dev lo proto kernel metric 256 pref medium
2001:41d0:206:cd1d::6153 dev ens3 proto kernel metric 256 pref medium
fe80::/64 dev ens3 proto kernel metric 256 pref medium
问题
是否有人对动态 IPv4 和静态 IPv6 有有效的网络规划配置?
当我使用手动设置它时它可以工作ip addr
,ip route
但我想要使用 netplan 进行永久配置。
我终于在 OVH 社区帖子VPS en IPv6 上找到了我的答案?网关?
正确的配置(对于这种特殊情况)是:
我不明白为什么,但是
routes
netplan 需要该部分来应用新的 IPv6 路由。gateway6
是不足够的。解决我所有使用 netplan 的 IPv6 问题的方法只是定义了地址。省略网关和路由。
试试这个配置:
重新启动后定义的地址+网关中断。
netplan apply
每次重新启动后都需要。只有当我将 ip6 更改为另一个值并返回时,它才有效。所以这是一种完全奇怪的行为。定义地址 + 网关 + 路由确实有效,但添加了不必要的路由。
定义地址只是成功了。在那里我玩弄了前缀长度
/128
:/64
和/56
。所有这些都在 OVH 专用服务器上为我工作。