0

0

Linux如何抓取网络数据包tcpdump使用方法

P粉602998670

P粉602998670

发布时间:2025-09-13 11:56:01

|

845人浏览过

|

来源于php中文网

原创

tcpdump是Linux下强大的网络抓包工具,用于故障排查与安全分析,支持接口监听、包过滤、保存及读取抓包文件,常用参数包括-i指定接口、-c限制数量、-n不解析主机名、-w保存数据、-r读取文件,并可通过BPF语法实现精确过滤,结合Wireshark可深度分析流量。

linux如何抓取网络数据包tcpdump使用方法

在Linux系统中,tcpdump 是一个强大的命令行网络抓包工具,可以用来捕获和分析网络接口上的数据包。它适用于网络故障排查、安全分析和性能监控等场景。下面介绍tcpdump的基本使用方法和常见用法。

安装tcpdump

大多数Linux发行版默认未安装tcpdump,可通过包管理器安装:
  • Ubuntu/Debian: sudo apt install tcpdump
  • CentOS/RHEL: sudo yum install tcpdumpsudo dnf install tcpdump

查看可用网络接口

使用 -D 选项列出所有可监听的网络接口:

sudo tcpdump -D
输出示例:
1.eth0
2.lo
3.wlan0

基本抓包命令

最简单的抓包命令是直接监听某个接口:

sudo tcpdump -i eth0
这会监听 eth0 接口上的所有数据包,并实时输出。

常用参数说明:

  • -i interface:指定监听的网络接口,如 eth0、wlan0
  • -c count:限制捕获的数据包数量,例如 -c 10 表示只抓10个包
  • -n:不解析主机名,显示IP地址(加快输出)
  • -nn:不解析端口名称(如显示22而不是ssh)
  • -v, -vv, -vvv:显示更详细的信息(v越多越详细)
  • -s snaplen:设置每个数据包捕获的字节数,默认65535字节可捕获完整包
  • -w filename:将数据包保存到文件,用于后续分析(如Wireshark)
  • -r filename:读取之前保存的抓包文件

常见使用示例

只抓指定数量的包并显示IP和端口
sudo tcpdump -i eth0 -c 5 -nn

保存数据包到文件
sudo tcpdump -i eth0 -c 10 -w capture.pcap
之后可用Wireshark打开 capture.pcap 分析。

从文件读取并解析
tcpdump -r capture.pcap -nn

抓指定主机的数据包
sudo tcpdump -i eth0 host 192.168.1.100

抓指定源或目标IP的包
sudo tcpdump -i eth0 src 192.168.1.100
sudo tcpdump -i eth0 dst 192.168.1.200

动态WEB网站中的PHP和MySQL:直观的QuickPro指南第2版
动态WEB网站中的PHP和MySQL:直观的QuickPro指南第2版

动态WEB网站中的PHP和MySQL详细反映实际程序的需求,仔细地探讨外部数据的验证(例如信用卡卡号的格式)、用户登录以及如何使用模板建立网页的标准外观。动态WEB网站中的PHP和MySQL的内容不仅仅是这些。书中还提到如何串联JavaScript与PHP让用户操作时更快、更方便。还有正确处理用户输入错误的方法,让网站看起来更专业。另外还引入大量来自PEAR外挂函数库的强大功能,对常用的、强大的包

下载

抓指定端口的流量(如HTTP)
sudo tcpdump -i eth0 port 80
sudo tcpdump -i eth0 port 443(HTTPS)

组合条件(使用and/or)
sudo tcpdump -i eth0 host 192.168.1.100 and port 22
sudo tcpdump -i eth0 src 192.168.1.100 and dst port 80

抓特定协议的数据包
sudo tcpdump -i eth0 icmp
sudo tcpdump -i eth0 tcp
sudo tcpdump -i eth0 udp

过滤表达式语法

tcpdump支持BPF(Berkeley Packet Filter)语法,常用表达式:
  • host 192.168.1.1
  • net 192.168.1.0/24
  • port 22
  • src host 192.168.1.100
  • dst port 80
  • tcp[tcpflags] & tcp-syn != 0(抓SYN包)

基本上就这些。掌握tcpdump能快速定位网络问题。建议结合 -w 和Wireshark进行深度分析。注意:抓包可能涉及隐私,需合法使用。

相关专题

更多
counta和count的区别
counta和count的区别

Count函数用于计算指定范围内数字的个数,而CountA函数用于计算指定范围内非空单元格的个数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

197

2023.11.20

硬盘接口类型介绍
硬盘接口类型介绍

硬盘接口类型有IDE、SATA、SCSI、Fibre Channel、USB、eSATA、mSATA、PCIe等等。详细介绍:1、IDE接口是一种并行接口,主要用于连接硬盘和光驱等设备,它主要有两种类型:ATA和ATAPI,IDE接口已经逐渐被SATA接口;2、SATA接口是一种串行接口,相较于IDE接口,它具有更高的传输速度、更低的功耗和更小的体积;3、SCSI接口等等。

1023

2023.10.19

PHP接口编写教程
PHP接口编写教程

本专题整合了PHP接口编写教程,阅读专题下面的文章了解更多详细内容。

66

2025.10.17

php8.4实现接口限流的教程
php8.4实现接口限流的教程

PHP8.4本身不内置限流功能,需借助Redis(令牌桶)或Swoole(漏桶)实现;文件锁因I/O瓶颈、无跨机共享、秒级精度等缺陷不适用高并发场景。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

439

2025.12.29

go中interface用法
go中interface用法

本专题整合了go语言中int相关内容,阅读专题下面的文章了解更多详细内容。

76

2025.09.10

http500解决方法
http500解决方法

http500解决方法有检查服务器日志、检查代码错误、检查服务器配置、检查文件和目录权限、检查资源不足、更新软件版本、重启服务器或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

359

2023.11.09

http请求415错误怎么解决
http请求415错误怎么解决

解决方法:1、检查请求头中的Content-Type;2、检查请求体中的数据格式;3、使用适当的编码格式;4、使用适当的请求方法;5、检查服务器端的支持情况。更多http请求415错误怎么解决的相关内容,可以阅读下面的文章。

410

2023.11.14

HTTP 503错误解决方法
HTTP 503错误解决方法

HTTP 503错误表示服务器暂时无法处理请求。想了解更多http错误代码的相关内容,可以阅读本专题下面的文章。

1881

2024.03.12

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

72

2026.01.16

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 7.4万人学习

Django 教程
Django 教程

共28课时 | 3.2万人学习

SQL 教程
SQL 教程

共61课时 | 3.5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

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