CentOS 6禁用IPv6解决curl Couldn’t resolve host或dns解析慢

说明:
在使用curl获取某接口时会curl: (6) Couldn’t resolve host ‘www.coolnull.com’。奇葩的是ping www.coolnull.com域名是通的。上网搜了下。
在CentOS6系统下,遇到最常见的问题就是curl: (6) Couldn’t resolve host ‘www.coolnull.com’。不仅仅curl会有这个问题,python的urllib2也有这个问题,报错的信息如下:urllib2.URLError:
还有个直观的问题就是,就是DNS域名解析变慢了,因为CentOS 6/REHL 6总是等待AAAA(IPv6)的查询结果。具体可以查看附录1:centos6需启用single-request-reopen参数
IPv6是为了解决IPv4地址耗尽的问题,但并不是所有人都需要它,也不是所有硬件都支持它。在某些情况下,可能会发现禁用IPv6不仅仅会加快网络,还会有助于减少管理开销和提高安全级别。

查看:
CentOS6 / RHCE6 系统默认已经启用IPv6了,如图所示:
v1
v2

解决:
1. 在/etc/resolv.conf文件中添加以下内容

options single-request-reopen

 
2. 修改/etc/sysctl.conf文件

net.ipv6.conf.default.disable_ipv6 = 1
net.ipv6.conf.all.disable_ipv6 = 1

# /sbin/sysctl -p 使禁用IPv6生效

 
3. 禁止加载IPv6模块。这个我倒是没有去尝试。

# echo "install ipv6 /bin/true" > /etc/modprobe.d/disable-ipv6.conf

每当系统需要加载IPv6模块时,强制执行/bin/true来代替实际加载的模块。注意:这是CentOS系统目前唯一有效的方法来禁用IPv6模块的。

4. 关闭ip6tables

# /etc/init.d/ip6tables stop
# chkconfig ip6tables off

 
5. 禁用基于IPv6网络,使之不会被触发启动

# vi /etc/sysconfig/network
NETWORKING_IPV6=no

 
6. 禁用网卡IPv6设置,使之仅在IPv4模式下运行。这个正常应该只有在网卡重启才会有效,所以也只是先暂时修改了下。

# vi /etc/sysconfig/network-scripts/ifcfg-ethX 或 vi /etc/sysconfig/network-scripts/ifcfg-em1X
IPV6INIT=no
IPV6_AUTOCONF=no

 
7. 重启生效

# reboot

 
8. 验证是否生效

# lsmod | grep ipv6

如果没有任何输出就说明IPv6模块已被禁用,否则被启用。

附录:
附录1:centos 6中single-request-reopen参数说明
原文参考自CentOS 6 / RHCE 6 禁用IPv6协议模块

发表评论

邮箱地址不会被公开。 必填项已用*标注