当前位置: 首页 > article >正文

Linux tcpdump 详解教程

简介

tcpdump 是一款在 Linux 平台上广泛使用的网络抓包工具。它可以捕获整个 TCP/IP 协议族的数据包,并支持对网络层、协议、主机、端口等进行过滤。tcpdump 提供了强大的过滤功能,允许使用 and、or、not 等逻辑语句来筛选数据包,非常适合用于网络故障分析和安全监控。

安装 tcpdump

在大多数 Linux 发行版上,可以使用包管理器安装 tcpdump。例如,在基于 Debian 的系统上:

sudo apt-get install tcpdump

在基于 Red Hat 的系统上:

sudo yum install tcpdump

tcpdump 命令选项

tcpdump 有很多命令选项,可以通过 tcpdump -hman tcpdump 查看所有选项的详细说明。以下是一些常用的选项:

  • -i interface:指定网络接口。
  • -w file:将捕获的数据包写入文件。
  • -r file:从文件中读取数据包。
  • -s snaplen:设置每个包的抓取长度,默认为68字节。
  • -c count:指定捕获数据包的数量。
  • -A:以ASCII码方式显示每个数据包的内容。
  • -X:同时以十六进制和ASCII码显示数据包内容。

基本使用

捕获所有接口的流量

sudo tcpdump -i any -w capture.pcap
  • -i any 表示监听所有网络接口。
  • -w capture.pcap 表示将捕获的数据保存到 capture.pcap 文件中。

捕获特定接口的流量

sudo tcpdump -i eth0 -w capture.pcap

捕获特定端口的数据包

sudo tcpdump -i eth0 port 80 -w capture.pcap

实时查看抓包数据

如果希望在抓包过程中实时查看数据,可以不使用 -w 选项,而是直接在终端输出:

sudo tcpdump -i eth0

高级过滤

tcpdump 支持复杂的过滤规则,例如:

  • 捕获特定主机的数据包:
tcpdump host 192.168.1.1
  • 捕获两个特定主机之间的数据包:
tcpdump host 192.168.1.1 and 192.168.1.2
  • 捕获特定协议的数据包:
tcpdump tcp
  • 捕获特定源端口或目的端口的数据包:
tcpdump portrange 1-1024

tcpdump 与 Wireshark

Wireshark 是一个图形界面的网络协议分析工具,可以与 tcpdump 结合使用。在 Linux 中使用 tcpdump 抓包,然后在 Windows 中使用 Wireshark 进行分析。保存数据包为 Wireshark 能识别的文件:

tcpdump tcp -i eth1 -t -s 0 -c 100 and dst port ! 22 and src net 192.168.1.0/24 -w ./target.cap
  • -t:不显示时间戳。
  • -s 0:抓取完整的数据包。
  • -c 100:捕获100个数据包。
  • -w ./target.cap:将数据包写入 target.cap 文件中。

通过上述教程,你应该能够掌握 tcpdump 的基本使用和一些高级功能,以便在 Linux 系统中进行网络数据包的捕获和分析。


http://www.kler.cn/a/405425.html

相关文章:

  • el-table最大高度无法滚动
  • 菜鸟驿站二维码/一维码 取件识别功能
  • Easyexcel(4-模板文件)
  • Vue2与Vue3:深入比较与迁移指南
  • Java实现简单的搜索引擎
  • Python网络爬虫实践案例:爬取猫眼电影Top100
  • 海盗王集成网关和商城服务端功能golang版
  • 重构代码之引入本地扩展
  • 【IOS】编译缓存错误Library/Caches/com.apple.mobile.installd.staging
  • 直流电表精准计量,为光伏产业续航
  • 2025蓝桥杯(单片机)备赛--扩展外设之UART1的原理与应用(十二)
  • 分治法的魅力:高效解决复杂问题的利器
  • 什么是axios?怎么使用axios封装Ajax?
  • 第1章 初识SpringMVC
  • 【滑动窗口】至少有k个重复字符的最长子串
  • 系统思考—跳出症状看全局
  • 【linux013】文件操作命令篇 - less 命令
  • python使用 `importlib.resources` 管理资源文件
  • FPC柔性线路板与智能生活的融合
  • 【电路笔记 TMS320F28335DSP】时钟+看门狗+相关寄存器(功能模块使能、时钟频率配置、看门狗配置)
  • Spark RDD(弹性分布式数据集)的深度理解
  • 向量数据库FAISS之五:原理(LSH、PQ、HNSW、IVF)
  • 基于深度学习的机动车驾驶重量识别预测研究思路,引入注意力,以及实验验证与性能评估
  • STM32 BootLoader 刷新项目 (十一) Flash写操作-命令0x57
  • Unity开发抖音小游戏使用长音频和短音频
  • Docker Compose安装部署PostgreSQL数据库