Linux怎么排查DNS解析失败问题

首先确认是否为DNS解析问题,使用ping和dig测试域名解析;接着检查/etc/resolv.conf文件中的nameserver配置是否有效;然后查看systemd-resolved或NetworkManager服务状态及配置,确保DNS设置正确;最后排查防火墙是否阻止UDP 53端口及网络连通性,逐步定位并解决DNS解析失败问题。

Linux怎么排查DNS解析失败问题

当Linux系统出现DNS解析失败时,表现为无法通过域名访问网站,但可能仍能通过IP地址访问。排查这类问题需要逐步检查网络配置、DNS设置和服务状态。以下是常见的排查步骤。

1. 使用ping和dig测试域名解析

先确认是DNS问题还是网络连通性问题。

尝试ping一个域名:

ping www.baidu.com

如果提示“Name or service not known”,说明DNS解析失败。

使用dig命令查看详细解析过程:

dig www.baidu.com

观察输出中的“ANSWER SECTION”是否有IP返回。如果没有,查看“SERVER”字段,确认使用的DNS服务器是否正确。

Linux怎么排查DNS解析失败问题

2. 检查/etc/resolv.conf配置

该文件定义了系统使用的DNS服务器。

查看内容:

cat /etc/resolv.conf

确保其中包含有效的nameserver,例如:

nameserver 8.8.8.8 nameserver 114.114.114.114

如果文件为空或DNS地址不合理,可手动添加公共DNS。注意:某些系统使用NetworkManager或systemd-resolved动态管理该文件,直接修改可能被覆盖。

Linux怎么排查DNS解析失败问题

3. 检查网络管理服务

现代Linux发行版常用systemd-resolved或NetworkManager管理DNS。

Linux怎么排查DNS解析失败问题

VisDoc

AI文生图表工具

Linux怎么排查DNS解析失败问题29

查看详情 Linux怎么排查DNS解析失败问题

查看systemd-resolved状态:

systemctl status systemd-resolved

查看其配置:

cat /etc/systemd/resolved.conf

如有必要,编辑该文件,在[Resolve]段中添加:

DNS=8.8.8.8 114.114.114.114 FallbackDNS=1.1.1.1

保存后重启服务:

systemctl restart systemd-resolved Linux怎么排查DNS解析失败问题

4. 检查防火墙和网络连通性

DNS使用UDP 53端口,部分防火墙可能阻止DNS请求。

测试是否能访问外部DNS服务器:

nc -uvz 8.8.8.8 53

如果连接失败,可能是防火墙或网络策略限制。检查iptables或firewalld规则。

同时确认系统默认路由正常:

ip route show default

确保有默认网关,且网络接口已正确获取IP。

基本上就这些。从应用层工具测试,到配置文件检查,再到服务和网络策略验证,逐步缩小问题范围,通常能快速定位DNS解析失败的原因。

linux 防火墙 工具 ai 路由 dns linux系统 dns解析失败 接口 default udp linux

上一篇
下一篇