NetworkManager and netplan
简介
Ubuntu 18.04开始,Ubuntu和Debian移除了以前的ifup/ifdown 命令和/etc/network/interfaces配置文件,转而使用ip link set 或者/etc/netplan/01-netcfg.yaml 模板和sudo netplan apply 命令实现网络管理。 Netplan 是抽象网络配置描述器,用于配置Linux 网络。 通过netplan 命令,你只需用一个 YAML文件描述每个网络接口所需配置。netplan 并不关系底层管理工具是NetworkManager还是networkd。 netplan的使用可能导致新版本Ubuntu重启后网络无法连通。
替代关系
ip link set 为iproute2 工具集命令,多用于临时配置,取代ifup 和ifdown 。 如果安装的是服务器版本,则默认使用networkd进行管理,并且不会安装NetworkManager和提供nmcli接口。 如果安装的是桌面版本,则默认使用NetworkManager进行管理。 这里的默认使用是指/etc/netplan/ 下的YAML配置文件中render初始指定为该网络管理工具。 如果是带有无线网络的移动设备,推荐使用NetworkManager,可以通过NetworkManager切换环境网络以及修改WiFi密码;如果是非移动的设备(或无需无线网络的虚拟机),更推荐networkd(无法管理WiFi和3/4/5G移动网络)作为后端管理工具,使用YAML描述文件+**sudo netplan apply** 生成后端配置,保证网络设置的静态性。
netplan工作原理
netplan 从/etc/netplan/ 文件夹中读取YAML配置文件,配置可以是管理员或者系统安装人员配置,可以参考该目录中的模板文件。 在系统启动阶段早期,netplan 在/run 目录生成好配置文件并将设备控制权交给相关后台程序。
Netplan 目前支持以下两种网络管理工具 :
NetworkManager Systemd-networkd
在YAML文件中通过renderer关键字进行描述,networkd和NetworkManager。 一言以蔽之,从前你需要根据不同的管理工具编写网络配置,现在**Netplan** 将管理工具差异性给屏蔽了。 你只需按照Netplan 规范编写YAML 配置,不管底层管理工具是啥,一份配置走天下!
配置
如下简单配置,NetworkManager会默认管理所有以太网设备和WiFi设备,默认以DHCP的方式启动这些以太网设备。而networkd则徐手动指定。
network :
version : 2
renderer : NetworkManager
注:
- YAML在Saltstack中使用两个空格进行缩进,一定不要使用Tab进行缩进。
- YAML的冒号后边如果还要文本,需要一个空格。
- 列表项的写法类似Markdown,-加上空格。
可以单独配置YAML,文件位于/etc/netplan 目录下且以.yaml结尾即可。示例如下:
network:
version: 2
renderer: networkd
ethernets:
enp0s3:
dhcp4: true
enp0s8:
addresses: [192.168.5.3/24]
routes:
- to: "default"
via: "192.168.5.1"
nameservers:
search: [mydomain , otherdomain ]
addresses: [192.168.5.1 , 114.114.114.114]
optional: true
这里的addresses: [192.168.56.3/24] 就是列表项,可以写作:
addresses:
- 192.168.56.3/24
如上[192.168.5.1 , 114.114.114.114] 的域名服务器设置,在通过netplan get 进行查看时,会显示为:
nameservers:
addresses:
- 192.168.5.1
- 114.114.114.114
整个配置为enp0s3 网卡开启DHCP ,该网络连接将自动获取地址;为enp0s8 网卡配置了一个静态IP192.168.5.3 ,掩码为24 位。
命令
完成了配置文件的描述,之后就可以进行通过netplan 通过针对后端管理工具生成配置文件。 netplan 操作命令提供常用子命令如下:
netplan generate :生成后端管理工具对应的配置;netplan apply :应用配置,必要时重启管理工具;netplan try :在配置得到确认之后才应用,如果配置存在错误,则回滚,类似test;netplan get :获取当前netplan配置;netplan set :修改当前netplan配置。
netplan --debug apply 返回错误信息。
示例
(选作操作)无移动设备桌面版(或移动设备虚拟机)需执行如下操作:
sudo systemctl status NetworkManager 停止NetworkManger.service;sudo systemctl disable NetworkManager 关闭NetworkManger.service开启自启。
必须步骤:
sudo cp /etc/netplan/01-network-manager-all.yaml{,.bak} 进行配置文件备份(打头的两位数字类似于udev中的优先级,这里不过多关心);sudo vim /etc/netplan/01-network-manager-all.yaml 修改配置文件,内容如下(自行修改):
network:
version: 2
renderer: networkd
ethernets:
enp0s25:
addresses: [192.168.5.243/24]
routes:
- to: default
via: 192.168.5.1
nameservers:
addresses: [192.168.5.1, 114.114.114.114]
sudo netplan apply 应用配置。 注:网关不确定的情况下,可以通过networkctl status 查看(如果使用的是VMware虚拟机,则.2地址为网关和本地DNS服务器)。
辅助命令
networkctl 可以查看网络设备的汇总信息,networkctl status 可以查看详情状态。
|