更新2
提案されたソリューションを適用する必要があるため、トップ投稿。
質問-2番目の回答 にあります
これはgithubのnetplanリポジトリで修正されており、おそらくいつかUbuntuに組み込まれるでしょう。
Dhcp4-overridesとdhcp6-overridesという2つの新しいオプションが追加されました。 DHCPからDNSサーバーを無視するには、次のようにします。
Ubuntu 18.04でネットプランを更新する方法を知っている人はいますか?
元の質問
2つのネットワークインターフェイスを備えたLXD vmを持っています。 Ubuntu 16.04(インターフェース)を使用している場合、1つのデフォルトゲートウェイがあります。 Ubuntu 18.04(netplan)を使用している場合、2つのデフォルトゲートウェイがあります。 2番目のゲートウェイを削除するにはどうすればよいですか?
Ubuntu 16.04の設定:
root@servizi:/etc/network/interfaces.d# ls -lha
total 3.5K
drwxr-xr-x 2 root root 4 Jul 31 2017 .
drwxr-xr-x 7 root root 8 Jul 12 2017 ..
-rw-r--r-- 1 root root 367 Jul 30 2017 50-cloud-init.cfg
-rw-r--r-- 1 root root 97 Jul 31 2017 60-locale.cfg
root@servizi:/etc/network/interfaces.d# cat 50-cloud-init.cfg
# This file is generated from information provided by
# the datasource. Changes to it will not persist across an instance.
# 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}
auto lo
iface lo inet loopback
auto eth0
iface eth0 inet dhcp
root@servizi:/etc/network/interfaces.d# cat 60-locale.cfg
auto eth1
iface eth1 inet dhcp
up route add -net 192.168.99.0 netmask 255.255.255.0 gw 10.0.1.1
root@servizi:/etc/network/interfaces.d# route -n
Kernel IP routing table
Destination Gateway Genmask Flags Metric Ref Use Iface
0.0.0.0 10.220.90.1 0.0.0.0 UG 0 0 0 eth0
10.0.1.0 0.0.0.0 255.255.255.0 U 0 0 0 eth1
10.220.90.0 0.0.0.0 255.255.255.0 U 0 0 0 eth0
192.168.99.0 10.0.1.1 255.255.255.0 UG 0 0 0 eth1
root@servizi:/etc/network/interfaces.d#
Ubuntu 18.04の設定
root@servizi2:/etc/netplan# ls -lh
total 2.0K
-rw-r--r-- 1 root root 381 Jan 24 17:30 50-cloud-init.yaml
-rw-r--r-- 1 root root 177 Feb 1 20:25 60-locale.yaml
root@servizi2:/etc/netplan# cat 50-cloud-init.yaml
# This file is generated from information provided by
# the datasource. Changes to it will not persist across an instance.
# 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:
eth0:
dhcp4: true
root@servizi2:/etc/netplan# cat 60-locale.yaml
# seconda scheda
network:
version: 2
ethernets:
eth1:
dhcp4: true
routes:
- to: 192.168.99.0/24
via: 10.0.1.1
root@servizi2:/etc/netplan# route -n
Kernel IP routing table
Destination Gateway Genmask Flags Metric Ref Use Iface
0.0.0.0 10.220.90.1 0.0.0.0 UG 100 0 0 eth0
0.0.0.0 10.0.1.1 0.0.0.0 UG 100 0 0 eth1
10.0.1.0 0.0.0.0 255.255.255.0 U 0 0 0 eth1
10.0.1.1 0.0.0.0 255.255.255.255 UH 100 0 0 eth1
10.220.90.0 0.0.0.0 255.255.255.0 U 0 0 0 eth0
10.220.90.1 0.0.0.0 255.255.255.255 UH 100 0 0 eth0
root@servizi2:/etc/netplan#
[〜#〜]更新[〜#〜]
@slangasekの提案を試しましたが、2番目のファイルは次のとおりです。
root@servizi2:/etc/netplan# cat 60-locale.yaml
# seconda scheda
network:
version: 2
ethernets:
eth1:
dhcp4: true
dhcp4-overrides:
use-routes: false
routes:
- to: 192.168.99.0/24
via: 10.0.1.1
しかし、netplanの試行で「不明なキーdhcp4-overrides」というエラーが表示されます
root@servizi2:/etc/netplan# netplan try
Error in network definition /etc/netplan/60-locale.yaml line 5 column 12: unknown key dhcp4-overrides
An error occurred: the configuration could not be generated
Reverting.
root@servizi2:/etc/netplan#
何ができますか?
Dhcpからのeth0とeth1の両方にデフォルトルートがあるようです。そして、eth0を通るデフォルトルートのみを使用したいとします。
DHCPサーバーが提供するデフォルトルートを無視するには、次のようにdhcp4-overrides
を使用する必要があります。
network:
version: 2
ethernets:
eth1:
dhcp4: true
dhcp4-overrides:
use-routes: false
routes:
- to: 192.168.99.0/24
via: 10.0.1.1
このオプションは、現在Ubuntu 18.04 LTS以降のリリースで利用可能なnetplan 0.95以降でのみサポートされています。