开头先吐槽一下,netplan的配置文件用yaml语法,有点难受。
多IP地址配置通常有两种情况,一种是单网卡,另一种是多网卡。netplan的配置文件在/etc/netplan/目录下,默认有个00-installer-config.yaml配置文件。可以所有网卡都写在一个配置文件中,但我更推荐可以根据逻辑区分配置文件写。
一、单网卡多IP配置示例
网卡名字/IP地址/dns地址等根据实际情况修改。
network:
version: 2
ethernets:
ens33:
addresses:
- "192.168.1.2/24"
- "192.168.2.2/24"
- "192.168.3.2/24"
nameservers:
addresses:
- 8.8.8.8
search: []
routes:
- to: "default"
via: "192.168.1.1"
可以通过检查是否有语法错误:
netplan get
如果没有问题,可以通过try命令尝试应用,会有确认机制,超时没有确认会回退。
netplan try
如果想直接应用,不需要尝试,也可以直接应用
netplan apply
二、多网卡多IP地址配置示例
network:
version: 2
ethernets:
ens33:
addresses:
- "192.168.1.2/24"
nameservers:
addresses:
- 8.8.8.8
search: []
routes:
- to: "default"
via: "192.168.1.1"
ens34:
addresses:
- "192.168.2.2/24"
ens35:
addresses:
- "192.168.3.2/24"
需要注意的是,多网卡多IP地址属于不同的运营商的话,需要手动增加策略路由,否则如果地址会被运营商的原进原出规则限制无法被公网访问。
关于策略路由,可以借助iproute2工具
1、假设192.168.2.0/24是联通,192.168.3.0/24是移动。全局电信可访问,那么创建联通和移动的vrf
echo "100 cnc" >> /etc/iproute2/rt_tables
echo "200 cmcc" >> /etc/iproute2/rt_tables
2、添加vrf路由,并把ip加入到路由规则即可。
ip route add default via 192.168.2.1 table cnc
ip route add default via 192.168.3.1 table cmcc
ip rule add from 192.168.2.2 table cnc
ip rule add from 192.168.3.2 table cmcc