ubuntu/centos系统ping 不通域名的解决方案

1. 确认网络基础连通性
bash 复制代码
# 测试能否ping通IP地址(如8.8.8.8)
ping -c 4 8.8.8.8
  • 现象判断
    • 若IP可通但域名不通 → DNS解析问题
    • 若IP和域名均不通 → 网络连接故障(需检查物理链路或防火墙)
2. 检查DNS服务器配置
  • 查看当前DNS配置

    bash 复制代码
    cat /etc/resolv.conf
    • 若文件为空或DNS服务器错误(如127.0.0.53),需手动添加:

      bash 复制代码
      sudo echo "nameserver 8.8.8.8" >> /etc/resolv.conf
      sudo echo "nameserver 114.114.114.114" >> /etc/resolv.conf
    • 注意:重启后可能恢复默认,需永久配置(见步骤3)。

3. 永久配置DNS(Netplan/NetworkManager)
  • Ubuntu 18.04+ 使用Netplan

    bash 复制代码
    sudo nano /etc/netplan/*.yaml  # 如01-network-manager-all.yaml

    添加DNS配置示例:

    yaml 复制代码
    network:
      version: 2
      ethernets:
        eth0:
          dhcp4: yes
          nameservers:
            addresses: [8.8.8.8, 114.114.114.114]

    应用配置:

    bash 复制代码
    sudo netplan apply
4. 验证nsswitch.conf配置
bash 复制代码
cat /etc/nsswitch.conf | grep hosts
  • 正确配置应为
    hosts: files dns [myhostname]
    若缺少dns,需编辑文件手动添加。
5. 检查关键库文件缺失
bash 复制代码
# 检查是否存在libnss_dns.so.2
ls /lib64/libnss_dns.so.2
  • 若缺失 ,手动创建软链接(假设库文件在/usr/lib/x86_64-linux-gnu/):

    bash 复制代码
    sudo ln -s /usr/lib/x86_64-linux-gnu/libnss_dns.so.2 /lib64/libnss_dns.so.2
6. 排查网络管理服务冲突
bash 复制代码
# 重启网络服务
sudo systemctl restart systemd-networkd
# 或停止NetworkManager(若存在冲突)
sudo systemctl stop NetworkManager
7. 防火墙及安全组检查
  • 本地防火墙

    bash 复制代码
    sudo ufw status  # 查看状态
    sudo ufw allow 53  # 开放DNS端口
  • 云服务器安全组
    确保安全组规则允许 ICMP协议UDP/TCP 53端口 出站。


8. 清理DNS缓存
bash 复制代码
sudo systemd-resolve --flush-caches  
# 或重启systemd-resolved服务
sudo systemctl restart systemd-resolved

9. 扩展测试
  • 手动解析测试

    bash 复制代码
    nslookup www.baidu.com 8.8.8.8
  • 抓包分析

    bash 复制代码
    sudo tcpdump -i eth0 port 53

常见问题汇总

现象 可能原因 解决方案
/etc/resolv.conf 重启后重置 DHCP覆盖或NetworkManager干扰 修改Netplan配置 或设置PEERDNS=no
仅部分域名解析失败 DNS污染或特定域名劫持 更换DNS服务器(如1.1.1.1
解析延迟高 DNS服务器性能差 更换响应更快的公共DNS
相关推荐
weixin_3077791327 分钟前
面向高性能保密计算的定制 Linux 系统构建与自动部署方案
linux·安全·网络安全·性能优化·系统安全
着迷不白30 分钟前
五、文本处理工具+正则表达式
linux·运维·服务器
载数而行52038 分钟前
Linux 4常用指令(文件/时间/搜索查找/压缩解压指令)
linux
不做无法实现的梦~1 小时前
MAVLink 协议教程
linux·stm32·嵌入式硬件·算法
实心儿儿2 小时前
Linux —— 线程控制(2)
linux·运维·服务器
烛衔溟2 小时前
TypeScript 模块与声明文件全解
linux·ubuntu·typescript
量子炒饭大师2 小时前
【Linux系统编程:进程概念】——【从 冯诺依曼系统体系结构 到 操作系统】
linux·运维·服务器·操作系统·冯诺依曼
2023自学中2 小时前
imx6ull 开发板,手机,MQTT 物联网通信实验。
linux·服务器·物联网·嵌入式·开发板·应用编程
f8979070702 小时前
把文件进行锁死,不要有写的权限。不被恶意攻击
linux
用户2367829801682 小时前
Linux kill 命令:从信号机制到进程管理的深度解析
linux