用 Dumpcap 进行网络故障排查的实操指南
一、快速准备
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、udp port 53、icmp、host 192.168.1.10)。http、tcp.port==443、icmp),用于聚焦分析。四、性能与稳定性建议
-B 1048576(单位字节)增大内核环形缓冲,减少高负载丢包。-a filesize:<字节> -a files:<数量> 实现循环写入,便于长时间抓包。五、分析要点与定位思路