netplan是一个抽象的网络配置描述器。通过netplan命令,你只需要使用一个yaml文件描述每个网络接口所需配置。netplan并不关系底层管理工具是NetworkManager还是networkd。
他是一个在Linux系统上进行网络配置的实用程序。我们创建所需接口的描述并定义每个接口应该做什么。
netplan 满足在yaml中跨一组多功能服务器、桌面、云或物联网安装进行简单、描述性网络配置的需求。
对于想要使用通过网络配置来控制不同后端(例如NetworkManager 或 systemd-networkd)的Linux系统管理员来说,他非常有用。
netplan是Ubuntu家族的成员,这是一个开源项目。
Ubuntu18.04 开始,Ubuntu的Debian移除了以前的ifup/ifdown命令和/etc/network/interfaces配置文件,转而使用 ip set 或 /etc/netplan/01-netcfg.yaml模板和 sudo netplan apply 命令实现网络管理。
ip link set 为 iproute2 工具集命令,多用于临时配置,取代ifup 和ifdown。
如果安装的是服务器版本,则默认使用networkd 进行管理,并且不会安装NetworkManager 和提供nmcil接口。
如果安装的是桌面版,则默认使用NetworkManager 进行管理。
netplan 目前支持的网络管理工具:
- NetworkManager
- systemd-networkd
Netplan、NetworkManager、Systemd-networkd 关系
netplay 支持调用 NetworkManager 和Systemd-networkd;
NetworkManager 和 Systemd-networkd 可以理解为互相替代关系;
如果要禁用 NetworkManager,则应启用 systemd-networkd,而在 systemd-networkd 运行时最好禁用 NetworkManager。
netplan 提供两个子命令:
- netplan generate:生成后端管理工具对应的配置;(/etc/netplan)
- netplan aply:应用配置以便生效,必要时重启管理工具;
- netplan try:在配置得到确认后才应用,如果配置存在错误,则滚回,类似test;
- netplan get:获取当前 netplan 配置;
- netplan set:修改当前 netplan 配置;
- netplan –debug apply:返回错误信息。
辅助命令:
- networkctl:可以查看网络设备的汇总信息;
- networkctl status:可以查看详情状态;
NetworkManager命令
- systemctl status NetworkManager 查看 NetworkManager 状态;
- systemctl start NetworkManager 开启 NetworkManager服务;
- systemctl restart NetworkManager 重启 NetworkManager服务(PID值会变化);
- systemctl reload NetworkManager 重新加载NetworkManager服务(PID值不会变化);
- systemctl is-enabled NetworkManager 查看 NetworkManager服务是否开机自启动;
- systemctl enable NetworkManager 设置 NetworkManager服务开机自启动;
Yaml 文件编写:
YAML在Saltstack中使用两个空格进行缩进,一定不要使用tab进行缩进;
YAML的冒号后面如果要有文本,需要一个空格;
列表项的写法类似 Markdown,-加上空格。
常用的Netplan参数
- version:指定Netplan配置文件的版本号。默认值为2;
- renderer:指定用于渲染网络接口配置的工具,常用值为networkd 和 NetworkManager ;
- ethernets:定义要配置的以太网接口及其属性,例如IP地址、子网掩码、网关、DNS等;
- bridges:定义要配置的网桥及其属性,例如IP地址、子网掩码、网关、DNS等;
- vlans:定义要配置的VLAN及其属性,例如Vlan ID、IP地址、子网掩码、网关、DNS等;
- bonds:定义要配置的绑定接口及其属性,例如负载均衡算法、网卡状态检测机制等。
- routes:定义静态路由表,指定路由器及其下一跳地址和子网掩码。
网络配置示例:
查看无线网卡名称:
ip link show
编辑.yaml配置文件
sudo nano /etc/netplan 00-installer-config.yaml 或 50-cloud-init.yaml 或 01-netcfg.yaml
netplan 支持两个网络后端:networkd 和 NetworkManager,一般为 networkd
network:
version: 2
renderer: networkd
如果networkd 不存在也可以使用NetworkManager
network:
version: 2
renderer: networkd
以太网连接:动态IP
network:
version: 2
renderer: networkd
ethernets:
eth0:
dhcp4: yes
eth1:
dhcp4:yes
以太网连接:静态IP
network:
version: 2
renderer: networkd
ethernets:
eth0:
addresses:
- 10.10.10.3/24
nameservers:
addresses: [202.96.128.86]
routes:
- to: 0.0.0.0/0
via: 10.10.10.1
eth1:
addresses:
- 10.10.10.2/24
nameservers:
addresses: [202.96.128.86]
routes:
- to: 0.0.0.0/0
via: 10.10.10.1
WIFI连接:静态IP
network:
version: 2
renderer: networkd
wifi:
wlan0:
dhcp4: no
dhcp6: no
addresses: [192.168.1.200/24]
nameservers:
addresses: [202.96.128.86]
access-points:
"401-wifi"
pwssword: "13417785555"
routes:
- to: 0.0.0.0/0
via: 192.168.1.1
WIFI连接:动态IP
network:
version: 2
renderer: networkd
wifi:
wlan0:
dhcp4:yes
access-points:
"401-wifi":
password: "13417785555"
操作流程:
1. 修改配置文件:
vim /etc/netplan/xxx.yaml
2. 测试配置文件:
netplan try
3. 应用配置文件:
netplan apply
4. 重启网络服务:
sudo systemctl restart system-networkd
或 sudo systemctl restart network-manager


