1 介绍
1.1 简介
Netplan是一个抽象网络配置描述器。通过netplan命令,你只需用一个 YAML文件描述每个网络接口所需配置。netplan并不关系底层管理工具是NetworkManager还是networkd。
它是一个在 Linux 系统上进行网络配置的实用程序。您创建所需接口的描述并定义每个接口应该做什么。
Netplan 满足在 YAML 中跨一组多功能服务器、桌面、云或物联网安装进行简单、描述性网络配置的需求。
对于想要使用通用网络配置来控制不同后端(例如 NetworkManager 或 systemd-networkd)的 Linux 系统管理员来说,它非常有用。
Netplan 是 Ubuntu 家族的成员。这是一个开源项目。
Ubuntu 18.04开始,Ubuntu和Debian移除了以前的ifup/ifdown命令和/etc/network/interfaces配置文件,转而使用ip link set或者/etc/netplan/01-netcfg.yaml模板和sudo netplan apply命令实现网络管理。
ip link set为iproute2工具集命令,多用于临时配置,取代ifup和ifdown。
如果安装的是服务器版本,则默认使用networkd进行管理,并且不会安装NetworkManager和提供nmcli接口。
如果安装的是桌面版本,则默认使用NetworkManager进行管理。
Netplan 目前支持的网络管理工具:
- NetworkManager
- Systemd-networkd
1.2 Netplan、NetworkManager、Systemd-networkd 关系
Netplan 支持调用 NetworkManager 和 Systemd-networkd;
NetworkManager和systemd-networked可以理解为相互替代关系。
如果要禁用NetworkManager,则应启用systemd-networkd,而在systemd-networkd运行时最好禁用networkmanager。
1.3 命令
netplan 操作命令提供两个子命令:
- netplan generate :生成后端管理工具对应的配置;(/etc/netplan)
- netplan apply :应用配置(以便生效),必要时重启管理工具;
- netplan try :在配置得到确认之后才应用,如果配置存在错误,则回滚,类似test;
- netplan get:获取当前netplan配置;
- netplan set:修改当前netplan配置。
- netplan --debug apply 返回错误信息。
辅助命令
networkctl 可以查看网络设备的汇总信息
networkctl status 可以查看详情状态。
NetworkManager 命令
systemctl status NetworkManager 查看NetworkManager状态
systemctl start NetworkManager 开启Net
systemctl restart NetworkManager 重新启动Net(PID值会发生变化)
systemctl reload NetworkManager 重新启动Net(PID值不会发生变化)
systemctl is-enabled NetworkManager 查看Net是否开机自启动
systemctl enable NetworkManager 设置Net开机自启动
1.4 YAML 文件编写
YAML在Saltstack中使用两个空格进行缩进,一定不要使用Tab进行缩进。
YAML的冒号后边如果还要文本,需要一个空格。
列表项的写法类似Markdown,-加上空格。
2 常用的Netplan参数
- version:指定Netplan配置文件的版本号,默认值为2。
- renderer:指定用于渲染网络接口配置的工具,常用的值为networkd(使用systemd-networkd)和NetworkManager(使用NetworkManager)。
- ethernets:定义要配置的以太网接口及其属性,例如IP地址、子网掩码、网关、DNS等。
- bridges:定义要配置的网桥及其属性,例如IP地址、子网掩码、网关、DNS等。
- vlans:定义要配置的VLAN接口及其属性,例如ID、IP地址、子网掩码、网关、DNS等。
- bonds:定义要配置的绑定接口及其属性,例如负载平衡算法、网卡状态检测机制等。
- nameservers:指定要使用的DNS服务器列表。
- routes:定义静态路由表,指定路由器及其下一跳地址和子网掩码。
3 网络配置示例
Netplan支持两个网络后端:networkd和NetworkManager,一般为networkd
network:
version: 2
renderer: networkd
如果networkd不存在,也可以使用NetworkManager。
network:
version: 2
renderer: NetworkManager
以太网连接:动态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:
"NETGEAR25":
password: "ceshizhuanyong"
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:
"NETGEAR25":
password: "ceshizhuanyong"
4 操作流程
4.1 修改配置文件
vim /etc/netplan/*.yaml
4.2 测试配置文件
netplan try
4.3 应用配置文件
netplan apply
4.4 重启网络服务
sudo systemctl restart system-networkd
或者
sudo systemctl restart network-manager
参考
1、Netplan documentation
2、YAML configuration
3、Netplan使用(高版本Ubuntu静态/动态IP设置方法)
4、Netplan新一代网络配置工具使用详解
5、Ubuntu 18.04 LTS 通过 Netplan 配置网络教程
6、Firefly-Linux-Guide/#network-configuration