您的位置:首页 >怎样用dumpcap进行网络故障排查
发布于2026-04-24 阅读(0)
扫一扫,手机访问

工欲善其事,必先利其器。动手抓包前,先把这几项基础工作做到位,能让你后续的操作事半功倍。
sudo apt update && sudo apt install wireshark dumpcap;如果是 CentOS/RHEL 系列,则运行 sudo yum install wireshark(Dumpcap 会随 Wireshark 一同提供)。安装完成后,别忘了用 dumpcap --version 命令验证一下版本,确保工具就绪。sudo setcap 'cap_net_raw,cap_net_admin+eip' /usr/bin/dumpcap。或者,也可以创建 wireshark 用户组,将用户加入后调整二进制权限——这在多人协作的运维环境中尤其方便。ip addr 或 ip link 确认好目标网卡接口名(比如常见的 eth0、ens33、wlan0),同时确保你对计划保存抓包文件的目录拥有读写权限。面对网络故障,最怕的就是一通乱抓。遵循一个清晰的流程,能让你的排查工作有条不紊。
理论说再多,不如几个实在的例子。下面这个表格,针对几种典型场景,给出了直接的命令和关键的观察方向。
| 故障场景 | 抓包命令示例 | 关键观察点 |
|---|---|---|
| 丢包或重传高 | sudo dumpcap -i eth0 -f "tcp" -w tcp.pcap |
TCP 重传(如 tcp.analysis.retransmission)、重复 ACK、窗口满 |
| 连接超时/握手失败 | sudo dumpcap -i eth0 -f "tcp port 443 or tcp port 80" -w handshake.pcap |
TCP 三次握手是否完成、是否有 RST、TLS 握手失败 |
| 高延迟/卡顿 | sudo dumpcap -i eth0 -f "tcp or icmp" -w latency.pcap |
请求与响应的时延、ICMP 超时/目的不可达 |
| DNS 解析慢/失败 | sudo dumpcap -i eth0 -f "udp port 53 or tcp port 53" -w dns.pcap |
响应时间、SERVFAIL/REFUSED、截断响应(TC) |
| 仅观察不落盘 | sudo dumpcap -i eth0 -w - | tcpdump -r - |
实时观察流量,不保存文件,用于快速检查 |
| 多文件循环写入 | sudo dumpcap -i eth0 -w trace.pcap -a filesize:100000 -a files:10 |
自动按大小滚动,避免磁盘被占满 |
这里需要区分两个概念:
tcp port 80, host 192.168.1.10),用于在数据进入捕获文件前就进行筛选,能极大减轻存储和分析压力。http, tcp.port==443),用于在已捕获的海量数据中快速聚焦到你关心的部分。抓包本身也可能成为问题。尤其是在高流量环境下,不注意这些细节,要么抓不到包,要么把系统拖垮。
-B 1048576(单位是字节)这类参数来增大内核环形缓冲区。这能有效减少在高负载下因处理不过来而导致的丢包。-a filesize:<字节> -a files:<数量> 参数实现循环写入。这对于需要长时间抓包监控的场景至关重要,能自动管理文件,避免撑爆磁盘。拿到一个抓包文件,从哪里看起?又该如何顺藤摸瓜?这里提供一些经典的思路。
上一篇:使命闹钟app如何防止被卸载
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
正版软件
正版软件
正版软件
正版软件
正版软件
1
2
3
7
9