Linux 下使用tcpdump进行网络分析原

简介

tcpdump 是一个命令行数据包分析器,可实时捕获和检查网络流量。它通常用于网络故障排除、性能分析和安全监控。

安装

  • Debian/Ubuntu

    sudo apt update && sudo apt install tcpdump -y

  • CentOS/RHEL

    sudo yum install tcpdump -y

  • macOS

    brew install tcpdump

基础语法

复制代码
tcpdump [options] [filter]

示例用法

在默认接口上捕获数据包

实时捕获并显示网络数据包。

复制代码
sudo tcpdump
列出可用网络接口
复制代码
sudo tcpdump -D

输出示例

复制代码
1. eth0
2. wlan0
3. lo

可以使用此列表中的接口名称来捕获特定接口上的数据包。

在特定接口上捕获数据包
复制代码
sudo tcpdump -i eth0
限制捕获的数据包数量

仅捕获 10 个数据包然后停止

复制代码
sudo tcpdump -c 10 -i eth0
将捕获的数据包保存到文件
复制代码
sudo tcpdump -i eth0 -w capture.pcap
从文件读取数据包
复制代码
sudo tcpdump -r capture.pcap
仅捕获特定协议
  • 仅 TCP 数据包

    sudo tcpdump -i eth0 tcp

  • 仅 UDP 数据包

    sudo tcpdump -i eth0 udp

  • 仅 ICMP(ping)数据包

    sudo tcpdump -i eth0 icmp

捕获特定主机的数据包

捕获来自/到 192.168.1.1 的流量

复制代码
sudo tcpdump -i eth0 host 192.168.1.1
捕获特定端口上的数据包
  • 捕获 HTTP 流量(端口 80)

    sudo tcpdump -i eth0 port 80

  • 捕获 SSH 流量(端口 22)

    sudo tcpdump -i eth0 port 22

从特定源或目标捕获数据包
  • 仅捕获来自源 192.168.1.100 的数据包

    sudo tcpdump -i eth0 src 192.168.1.100

  • 仅捕获目的地址为 192.168.1.100 的数据包

    sudo tcpdump -i eth0 dst 192.168.1.100

组合多个过滤器

在端口 443 (HTTPS) 上捕获往返于 192.168.1.100 的 TCP 流量

复制代码
sudo tcpdump -i eth0 tcp and host 192.168.1.100 and port 443
以十六进制和 ASCII 格式显示数据包
复制代码
sudo tcpdump -X -i eth0
无需解析主机名即可捕获数据包

-n 选项可防止 DNS 查找,从而提高性能

复制代码
sudo tcpdump -n -i eth0
仅捕获数据包头(无有效负载)

-s 0 标志捕获完整的数据包而不是截断

复制代码
sudo tcpdump -s 0 -i eth0
仅捕获 HTTP 流量并显示内容

-A 选项以 ASCII 格式打印数据包内容

复制代码
sudo tcpdump -A -i eth0 port 80
相关推荐
A小辣椒11 小时前
TShark:Wireshark CLI 功能
linux
A小辣椒15 小时前
TShark:基础知识
linux
AlfredZhao17 小时前
OCI 明明分配了 200G 系统盘,为什么 df 只看到 30G?
linux·oci
AlfredZhao1 天前
vi 删除指定范围的行,不用再反复按 dd
linux·vi
用户9718356334662 天前
银河麒麟 KY10 申威(SW64) 安装 nginx-1.16.1-2.p01.ky10.sw_64.rpm 详细步骤
linux
猪脚踏浪2 天前
linux 拷贝文件或目录到指定的位置
linux
摇滚侠2 天前
Linux CentOS7 rpm 安装 MySQL 5.7
linux·运维·mysql
bush42 天前
嵌入式linux学习记录十四、术语
linux·嵌入式
载数而行5202 天前
Linux 11 动态监控指令top
linux
网络研究院2 天前
2026年网络安全
网络·安全·法律·法规·趋势·发展