zstack分配的虚拟机的dns设置

环境:

$ 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

posted @ 2017-09-18 16:16  脚本小娃子  阅读(905)  评论(0编辑  收藏  举报