最近在使用Ubuntu Server 22.04做项目开发测试时发现每次重启和关机后,所设置的静态IP地址都会回复到安装系统时所设置的ip.
nano /etc/netplan/50-cloud-init.yaml
当时没注意看上面画红框的提示部分,大意就是此文件的配置可能会在每次系统重启时被cloud云文件配置的内容所进行覆盖,可以通过禁用 cloud-init 的网络配置来防止这种情况发生。
我靠这就比较坑了,因为之前用centos7.6做开发时没有类似问题,之前还以为设置为静态IP地址就完事了,包括很多网上的修改静态IP地址教程也是这样写的,没想到Ubuntu居然还有默认云覆盖的机制(也可能是在我安装系统时没注意看勾选错了还是怎么的,至少我装了两个系统都有这个问题)
果然设置完192.168.3.229的IP地址后,系统重启马上又被修改成192.168.3.228
比较好奇,另一个配置文件在哪里,毕竟如果要覆盖配置文件的话,那么另外一个地方必然有保存原始云配置文件的,在启动后进行读取强行覆盖到当前配置文件才对。
进入云配置目录,可以看到有个90-installer-network.cfg的文件
ls /etc/cloud/cloud.cfg.d
查看90-installer-network.cfg文件,可以看到此处保留了系统安装时配置的IP地址
cat /etc/cloud/cloud.cfg.d/90-installer-network.cfg
通过上面,已经知道了设置netplan的静态ip地址时重启后IP地址被覆盖的原因,接下来就是解决问题了。
解决方案
1.直接修改云配置文件IP
直接把90-installer-network.cfg文件的IP配置进行修改成需要的参数,这样虽然也行但是比较容易给后面使用Ubuntu服务器不熟悉的人挖坑,例如服务器需要迁移网络环境部署需要修改网络配置折腾半天弄不了。
2.禁用cloud-init的网络配置
这是netplan里推荐的做法,接下来我们使用这个方式解决重启后IP地址被覆盖问题。
编辑 cloud-init 配置文件:
如果没有此文件直接创建再进行编辑
sudo nano /etc/cloud/cloud.cfg.d/99-disable-network-config.cfg
添加以下内容:
network: {config: disabled}
本文为宁若水!原创文章,转载无需和我联系,但请注明来自[若水]博客 www.lalaya.net