首页 > 运维 > linux运维 > 正文

如何排查Linux网络故障 常见网络问题诊断流程

P粉602998670
发布: 2025-08-05 13:28:01
原创
1190人浏览过

先判断是本机还是网络环境问题,询问他人、测试不同服务或更换网络环境;2. 使用ip addr show检查网卡状态和ip分配,启用网卡或重新获取dhcp地址;3. 依次ping 127.0.0.1、网关、8.8.8.8、域名,确认协议栈、局域网、公网连通性和dns解析;4. 查看ip route show确认默认路由和目标路由,缺失则手动添加;5. 检查iptables、firewalld或ufw防火墙规则,必要时临时关闭测试;6. 用telnet或nc测试端口连通性,服务端用ss -tulnp检查服务监听状态;7. 使用tcpdump抓包分析请求与响应,定位故障环节;常见问题包括无ip(dhcp失败)、能上内网不能上外网(路由缺失)、能ping ip不能访问网站(dns问题)、所有ping超时(网络中断或防火墙拦截)、特定端口不通(服务未启动或防火墙限制),排查应由近及远,结合ping、ip、nslookup、ss和tcpdump工具完成诊断,最终精准定位并解决问题。

如何排查Linux网络故障 常见网络问题诊断流程

排查Linux网络故障需要系统性地检查各个网络层次,从本地配置到远程连接,逐步缩小问题范围。以下是常见的网络问题诊断流程,适用于大多数Linux发行版。


一、确认问题范围:是本机问题还是网络环境问题?

首先判断问题是出在本机,还是整个网络环境或远程服务。

  • 询问其他用户:同一局域网内的其他设备是否也出现网络异常?
  • 尝试访问不同服务:比如能否访问公司内网?能否访问公网(如 google.com)?
  • 更换网络环境测试:比如切换到手机热点,看是否恢复正常。

如果只有本机出问题,继续排查本机配置;如果所有设备都异常,可能是路由器或ISP问题。


二、检查本机网络接口状态

使用基础命令查看网卡是否启用、IP是否正确分配。

ip addr show
# 或使用旧命令
ifconfig -a
登录后复制

关注点:

  • 网卡(如 eth0、ens33、wlan0)是否处于
    UP
    登录后复制
    状态。
  • 是否有正确的IP地址(非 169.254.x.x,那是链路本地地址,说明DHCP失败)。
  • 是否有丢包或错误计数(
    RX/TX errors
    登录后复制
    )。

若网卡未启用:

sudo ip link set eth0 up
登录后复制

若使用DHCP,可尝试重新获取IP:

sudo dhclient eth0
登录后复制

三、测试网络连通性

1. 测试本地协议栈是否正常

ping 127.0.0.1
登录后复制

如果失败,说明TCP/IP协议栈或内核网络模块有问题(极少见)。

2. 测试局域网连通性

ping 192.168.1.1   # 替换为你的网关
登录后复制
  • 能通:说明本机到路由器链路正常。
  • 不通:检查网线、Wi-Fi连接、网关IP是否正确(可通过
    ip route | grep default
    登录后复制
    查看默认网关)。

3. 测试公网连通性(IP层面)

ping 8.8.8.8
登录后复制
  • 能通:说明网络出站正常,可能是DNS问题。
  • 不通:说明路由或NAT有问题,检查默认路由和防火墙。

4. 测试域名解析(DNS)

ping google.com
登录后复制
  • 若能ping通IP但不能解析域名,说明DNS异常。

检查DNS配置:

cat /etc/resolv.conf
登录后复制

确保有有效的DNS服务器,如:

nameserver 8.8.8.8
nameserver 114.114.114.114
登录后复制

测试DNS解析:

nslookup google.com
# 或
dig google.com
登录后复制

若解析失败,可临时更换DNS服务器测试。


四、检查路由表

查看数据包是否知道如何到达目标网络:

ip route show
登录后复制

route -n
登录后复制

关键点:

知网AI智能写作
知网AI智能写作

知网AI智能写作,写文档、写报告如此简单

知网AI智能写作 38
查看详情 知网AI智能写作
  • 是否有默认路由(
    default via 192.168.1.1 dev eth0
    登录后复制
    )?
  • 目标网络是否有对应路由?

若缺失默认路由,手动添加:

sudo ip route add default via 192.168.1.1 dev eth0
登录后复制

五、检查防火墙设置

Linux本地防火墙可能阻止出站或入站流量。

  • 对于

    iptables
    登录后复制

    sudo iptables -L -n -v
    登录后复制

    查看是否有DROP规则影响网络。

  • 对于

    firewalld
    登录后复制
    (CentOS/RHEL):

    sudo firewall-cmd --state
    sudo firewall-cmd --list-all
    登录后复制
  • 对于

    ufw
    登录后复制
    (Ubuntu):

    sudo ufw status
    登录后复制

可临时关闭防火墙测试:

sudo systemctl stop firewalld
# 或
sudo ufw disable
登录后复制
测试后记得恢复。

六、检查服务和端口连通性

若特定服务无法访问(如无法SSH、无法访问网页):

  • 使用
    telnet
    登录后复制
    nc
    登录后复制
    测试端口:
    telnet 192.168.1.100 22
    # 或
    nc -zv 192.168.1.100 80
    登录后复制
  • 若连接超时或拒绝,可能是服务未运行或被防火墙拦截。

在服务端检查:

ss -tulnp | grep :22
# 或
netstat -tulnp | grep :22
登录后复制

确认服务是否监听正确IP和端口。


七、抓包分析(高级诊断)

当上述方法无法定位问题时,使用

tcpdump
登录后复制
抓包分析:

sudo tcpdump -i eth0 host 8.8.8.8
登录后复制

或抓ICMP包:

sudo tcpdump -i eth0 icmp
登录后复制

观察是否有请求发出、是否有响应返回,判断是发不出去还是收不到回应。


常见问题快速对照表

现象 可能原因 检查命令
无IP地址 DHCP失败或网卡未启用 @@######@@、@@######@@
能上内网不能上外网 默认路由缺失 @@######@@
能ping IP不能访问网站 DNS问题 @@######@@、@@######@@
所有ping都超时 网络不通或防火墙拦截 @@######@@、@@######@@
特定端口不通 服务未启动或防火墙限制 @@######@@、@@######@@

基本上就这些步骤。网络故障排查讲究由近及远:先本地配置,再网关,再DNS,最后外部因素。掌握

ip addr
登录后复制
dhclient
登录后复制
ip route
登录后复制
cat /etc/resolv.conf
登录后复制
dig
登录后复制
这几个工具,90%的常见问题都能定位。不复杂,但容易忽略细节。

ping 网关
登录后复制
tcpdump
登录后复制
ss -tuln
登录后复制
firewall-cmd
登录后复制
ping
登录后复制
ip
登录后复制
nslookup
登录后复制
ss
登录后复制
tcpdump
登录后复制

以上就是如何排查Linux网络故障 常见网络问题诊断流程的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号