环境:
$ uname -a Linux 10-57-19-61 2.6.32-504.el6.x86_64 #1 SMP Wed Oct 15 04:27:16 UTC 2014 x86_64 x86_64 x86_64 GNU/Linux $ cat /etc/redhat-release CentOS release 6.6 (Final)
本文介绍三种修改dns的方法:
方法一:dhcp client从dhcp server获取dns,同时可以通过配置/etc/sysconfig/network-scripts/ifcfg-*添加其他dns;===>[ dns=yes; PEERDNS=yes DNS20=xxxx ]
方法二:不使用从dhcp server处获得的dns,使用配置/etc/sysconfig/network-scripts/ifcfg-*里的dns信息生成/etc/resolv.conf;===>[ dns=yes; PEERDNS=no DNS1=xxx DNS2=xxx ]
方法三:即不使用从dhcp server处获得的dns,也不使用配置/etc/sysconfig/network-scripts/ifcfg-*里的dns信息,手动配置/etc/resolv.conf ===>[dns=no; PEERDNS=no ]
方法一:
1、zstack管理的虚拟机(CentOS release 6.6 (Final))dns是由zstack统一配置的,zstack相当于配置的是DHCP server的dns信息
2、配置下面的dns
3、这样新申请的机器,每次重启后,拥有的配置就是这两条配置
4、另外,根据参考的文章,还可以修改/etc/sysconfig/network-scripts/ifcfg-eth0的配置
注意,配置是DNS1=x.x.x.x,这里DNS之后的数值表示是第一条DNS配置,数值从 1 开始,必须有这个数字,这个序号表示在/etc/resolv.conf里的上下顺序
然后重启虚拟机或者service network restart,再次查看cat /etc/resolv.conf,生效,可以查看到新添加的DNS
如果已经存在序号为1的配置,再配置DNS1,不生效
上面这种方式的作用是,除了从DHCP服务器获得的dns外,另外添加dns,不会覆盖从服务器获取的dns
方法二:
1、另外根据鸟哥的文章,修改ifcfg-eth0的配置,然后重启网络,这样每次重启网络(service network restart)或者重启设备(sudo reboot),/etc/resolv.conf里的配置都是下面的三条DNS
方法三:
1、如果/etc/NetworkManager/NetworkManager.conf里设置dns=none;同时在配置/etc/sysconfig/network-scripts/ifcfg-*里设置PEERDNS=no,这样dns信息的来源就是手动配置的/etc/resolv.conf文件
dns=one + PEERDNS=no ==> 手动配置的/etc/resolv.conf在设备重启和service network restart两种情况下都会保持不变
2、在配置/etc/NetworkManager/NetworkManager.conf里设置dns=none使得网络管理不再管理dns配置。如果删除这条配置,那么重启网络服务(service network restart),网络服务会在/etc/sysconfig/network-scripts/ifcfg-*配置里查找dns配置(DNS1=xxx),然后使用这些配置生成/etc/resolv.conf文件,供dns解析使用
cat /etc/NetworkManager/NetworkManager.conf
[main]
plugins=ifcfg-rh
dns=none
3、在配置/etc/sysconfig/network-scripts/ifcfg-*里设置PEERDNS=no,表示不使用DHCP传过来的服务器配置,直接使用人工配置的/etc/resolv.conf文件,重启网络,也不会重新生成/etc/resolv.conf文件
4、由于bug(见参考2)的存在,实现2(PEERDNS=no),必须先配置1(dns=none),新的系统,可能已经解决这个问题
5、需要重启设备(reboot)使配置1生效(dns=none),不然,使用命令service network restart后,会使用/etc/sysconfig/network-scripts/ifcfg-*里的dns配置生成文件/etc/resolv.conf
6、这样所有的dns以手工配置的/etc/resolv.conf为准
重要提醒:
1、另外resolve.conf里的DNS只支持3条配置,然后轮询查找,依次从上往下查找
2、这个还牵扯到redhat的一个20170801份关闭的一个bug:https://bugzilla.redhat.com/show_bug.cgi?id=1405431
3、要使配置在reboot和service network restart两种情况下都不变
总结一下:目前系统现状是 dns=none配置表示不使用/etc/sysconfig/network-scripts/ifcfg-*里的dns配置;PEERDNS=no表示不使用dhcp server传过来的dns配置
参考:
1、http://blog.csdn.net/w670328683/article/details/61923858
2、http://cn.linux.vbird.org/linux_server/0350dns.php
3、https://ma.ttias.be/centos-7-networkmanager-keeps-overwriting-etcresolv-conf/
4、https://askubuntu.com/questions/623940/network-manager-how-to-stop-nm-updating-etc-resolv-conf