黑白格子

  • 首页
  • 所有文章
  • 文章分类
  • 关于页面
  • 友链

  • 搜索
随笔 脚本 Shell MAC IE SSL iptables 网络 k8s docker ubuntu web 镜像 Nginx Linux Windows cloud-init

ping域名提示 unknown host,ping IP正常,nslookup解析域名正常怎么解决?

发表于 2020-06-05 | 分类于 Linux | 0 | 阅读次数 163

问题现象:

ping 域名时不能解析域名,ping IP可以,初步看机器网络是正常的
root@BJ-CentOS7 ~ # ping baidu.com
ping: unknown host baidu.com
root@BJ-CentOS7 ~ # ping -c 2 8.8.8.8
PING 8.8.8.8 (8.8.8.8) 56(84) bytes of data.
64 bytes from 8.8.8.8: icmp_seq=1 ttl=251 time=96.6 ms
64 bytes from 8.8.8.8: icmp_seq=2 ttl=251 time=100 ms
--- 8.8.8.8 ping statistics ---
2 packets transmitted, 2 received, 0% packet loss, time 1001ms
rtt min/avg/max/mdev = 96.635/98.431/100.227/1.796 ms

问题分析:

从问题现象看,这里我们怀疑是不是 DNS 配置有问题呢?于是测试发现nslookup可以正常解析域名,DNS配置是没错的
root@BJ-CentOS7 ~ # nslookup baidu.com
Server:     183.60.83.19
Address:    183.60.83.19#53
Non-authoritative answer:
Name:   baidu.com
Address: 123.125.115.110
Name:   baidu.com
Address: 220.181.57.216
root@BJ-CentOS7 ~ # grep nameserver /etc/resolv.conf 
nameserver 183.60.83.19
nameserver 183.60.82.98

这里查阅资料了解到,原来 ping 程序解析域名依赖于C库中的函数 gethostbyname() 和 gethostbyaddr(),而这里对应的配置文件 /etc/nsswitch.conf 中的hosts 配置项:

files 表示使用 /etc/hosts 和 /etc/network 配置文件
dns 表示使用 /etc/resolv.conf 文件中的 DNS解析地址
nis 表示查询NIS系统的配置信息
root@BJ-CentOS7 ~ # grep hosts /etc/nsswitch.conf
#hosts:     db files nisplus nis dns
hosts:      files 
root@BJ-CentOS7 ~ # cat /etc/hosts
127.0.0.1  localhost  localhost.localdomain  VM_1_10_centos
root@BJ-CentOS7 ~ # ping -c 2 localhost
PING localhost (127.0.0.1) 56(84) bytes of data.
64 bytes from localhost (127.0.0.1): icmp_seq=1 ttl=64 time=0.023 ms
64 bytes from localhost (127.0.0.1): icmp_seq=2 ttl=64 time=0.035 ms
--- localhost ping statistics ---
2 packets transmitted, 2 received, 0% packet loss, time 999ms
rtt min/avg/max/mdev = 0.023/0.029/0.035/0.006 ms

验证发现果然写在 hosts 文件中的地址可以正常被 ping 程序解析,问题基本清楚,nslookup 是直接使用 /etc/resolv.conf 中的 DNS 服务器解析域名,而 ping 程序在没有在 /etc/nsswitch.conf 中的 hosts: dns 选项,所以无法解析 /etc/hosts 文件中不存在的解析记录

解决方案:

在 /etc/nsswitch.conf 文件的 hosts 配置项中添加 dns 选项,则可以使用 /etc/resolv.conf 中的 DNS 服务器解析域名,再次测试,可以正常解析域名了
root@BJ-CentOS7 ~ # grep hosts /etc/nsswitch.conf
#hosts:     db files nisplus nis dns
hosts:      files dns
root@BJ-CentOS7 ~ # ping -c 2 baidu.com
PING baidu.com (220.181.57.216) 56(84) bytes of data.
64 bytes from 220.181.57.216: icmp_seq=1 ttl=250 time=9.05 ms
64 bytes from 220.181.57.216: icmp_seq=2 ttl=250 time=9.06 ms
--- baidu.com ping statistics ---
2 packets transmitted, 2 received, 0% packet loss, time 1001ms
rtt min/avg/max/mdev = 9.051/9.057/9.063/0.006 ms
  • 本文作者: 黑白格子
  • 本文链接: https://www.clhuang.cn/?p=36
  • 版权声明: 本博客所有文章除特别声明外,均采用CC BY-NC-SA 4.0 许可协议。转载请注明出处!
# 随笔 # 脚本 # Shell # MAC # IE # SSL # iptables # 网络 # k8s # docker # ubuntu # web # 镜像 # Nginx # Linux # Windows # cloud-init
容器服务使用kubectl操作集群报错 is already registered
MAC 使用 Microsoft Remote Desktop 远程连接 Windows 服务器
黑白格子

黑白格子

54 日志
11 分类
17 标签
Creative Commons
0%
© 2021 黑白格子
主题 - NexT.Mist
网站已稳定运行:
陕ICP备16020191号