解决Linux重启后resolv.conf文件被重置问题
问题描述
修改云服务器规格的时候,会修改/etc/resolv.conf 文件和网卡配置,用户不希望/etc/resolv.conf 被修改。
问题原因
此问题为Linux本身问题与产品无关,从Centos5.6就存在,Centos重新启动网络服务自动使用/etc/sysconfig/network-scripts/ifcfg-eth0中重新置/etc/resolv.conf,导致修改/etc/resolv.conf内容, dhclient -> dhclient-scripts -> resolve.conf
[root@iv-yckhnozvhskrke7qy7lw ~]# cat /etc/resolv.conf
options timeout:5 attempts:3 rotate single-request-reopen
; generated by /usr/sbin/dhclient-script options rotate
nameserver 100.96.0.2 nameserver 100.96.0.3
[root@iv-yckhnozvhskrke7qy7lw ~]#
解决方案
用户需求:修改云服务规格、重启网络或机器不重置/etc/resolv.conf 文件。
方案一:
使用chattr +i 命令将resolv.conf文件变成只读,则dhclient无法修改resolv.conf文件
#锁定/etc/resolv.conf
sudo chattr +i /etc/resolv.conf
#解除锁定
sudo chattr -i /etc/resolv.conf
**持久化:**可以将sudo chattr +i /etc/resolv.conf加到/etc/rc.local里
方案二:在网卡里设置DNS,以Centos 7.6为例
vim /etc/sysconfig/network-scripts/ifcfg-eth0
#注意备份ifcfg-eth0信息 增加自定义DNS服务器,
如示例DNS1=8.8.8.8 #谷歌dns服务器
systemctl restart network #重启网络服务使配置生效,会影响 DNS 解析,请评估后操作。
执行后查看/etc/resolv.conf,就会把原来DNS覆盖为eth0网卡下配置,如下所示
[root@iv-yckhnozvhskrke7qy7lw network-scripts]# cat /etc/resolv.conf
options timeout:5 attempts:3 rotate single-request-reopen
options rotate
; generated by /usr/sbin/dhclient-script
nameserver 8.8.8.8 #会被8.8.8.8覆盖
——————————————
关注博主公众号,获取最新技术博文:
谢谢您的关注
评论前必须登录!
注册