Linux - Tcpdump命令

2024-09-06 01:58
文章标签 linux 命令 tcpdump

本文主要是介绍Linux - Tcpdump命令,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、说明
   
是一个用于抓取网络数据包并输出的工具,命令格式如下:
       tcpdump [ -AdDeflLnNOpqRStuUvxX ] [ -c count ][ -C file_size ] [ -F expr_file ][ -i interface ] [ -m module ] [ -M secret ][ -r read_file ] [ -s snaplen ] [ -T type ] [ -w save_file ][ -W file_count ][ -E spi@ipaddr algo:secret,...  ][ -y datalinktype ] [ -Z user ][ expression ]

二、选项
    -A     以ASCII格式打印出所有信息包并将链路层的头最小化。 
    -c     在收到指定的数量的数据包后退出
    -C     将数据包以一百万字节为单位的file_size指定的大小写入连续的多个文件中
    -d     将匹配的数据包的代码以可读的形式输出到标准输出
    -dd    将匹配的数据包的代码以c语言程序段的格式给出 
    -ddd   将匹配的数据包的代码以十进制的形式给出 
    -D     打印出系统中所有tcpdump可以抓取包的网络接口列表 
    -e     在输出行打印出数据链路层的头部信息 
    -E     用 spi@ipaddr algo:secret 解密那些以addr作为地址并且包含了安全参数索引值spi的IPsec ESP包 
    -f     以数字而非符号方式显示外来 IPv4 地址
    -F     从指定的文件中读取过滤表达式,忽略命令行中给出的表达式 
    -i     指定监听的网络接口,可以通过-D查看 
    -l     使标准输出变为缓冲行形式,可以把数据导出到文件 
    -L     列出网络接口的已知数据链路 
    -m     从其指定的Module文件中导入SMI MIB模块定义
    -M     如果TCP报文中存在TCP-MD5选项,使用secret作为用于验证TCP分段中签名的共享密钥
    -n     不把网络地址转换成名称
    -nn    不把协议和端口号转换成名称
    -N     不输出主机名中的域名部分
    -O     不运行数据包匹配的代码优化器 
    -p     不将网络接口设置成混杂模式。 
    -q     只输出较少的协议信息一遍快速输出 
    -r     从指定的文件中读取包(这些包一般通过-w选项产生) 
    -S     将Tcp的序列号以绝对值而非相对值的形式输出
    -s     从每个数据包中读取最开始的snaplen个字节,而不是默认的68个字节
    -T     将监听到的包直接解释为type指定类型的报文,常见的类型有rpc和snmp等
    -t     不在每一行中输出时间戳
    -tt    在每一行中输出非格式化的时间戳 
    -ttt   在本行和前面一行之间输出一个时间差
    -tttt  在每一行中输出由date处理的默认格式的时间戳
    -u     输出未解码的NFS句柄 
    -v     输出一个稍微详细的信息,例如在Ip包中可以包括ttl和服务类型的信息
    -vv    输出更为详细的报文信息
    -w     直接将数据包写入save_file文件中,而不是不解析并打印出来
    -W     与-C一起使用以限制创建文件的数量,达到file_count则开始覆盖
    -x     以十六进制显示每个信息包,减去其链接级别标题
    -xx    以十六进制显示每个信息包,包括其链接级别标题
    -X     以十六进制和ASCII显示每个信息包,减去其链接级别标题
    -y     设置在将信息包捕获到datalinktype时要使用的数据链路类型


三、表达式
    表达式用于过滤报文的条件,如果没有则抓取所有的数据包,表达式有三种类型的关键字:
    第一种是关于类型的关键字,主要的类型包括 host、net、port,缺省为host
    第二种是传输方向的关键字,主要的方向包括 src、dst、src or dst、src and dst,缺省为 src or dst
    第三种是通信协议的关键字,主要的协议包括 wlan、ip、ip6、arp、rarp、decnet、tcp、udp,缺省时监听所有协议


四、输出内容

[root@xl usr]# tcpdump -e -nn -S -X host 192.168.2.231 
tcpdump: verbose output suppressed, use -v or -vv for full protocol decode
listening on eth0, link-type EN10MB (Ethernet), capture size 96 bytes
11:18:40.804021 00:22:64:2d:35:1c > 00:0c:29:85:0b:14, ethertype IPv4 (0x0800), 
length 74: 192.168.3.43.57889 > 192.168.2.222.8080: S 1808454045:1808454045(0) 
win 5840 <mss 1460,sackOK,timestamp 113878982 0,nop,wscale 7>0x0000:  4510 003c 765b 4000 4006 3d3b c0a8 02e7  E..<v[@.@.=;....0x0010:  c0a8 02de e221 1f90 6bca d19d 0000 0000  .....!..k.......0x0020:  a002 16d0 bc70 0000 0204 05b4 0402 080a  .....p..........0x0030:  06c9 a7c6 0000 0000 0103 0307            ............
    第一行:执行tcpdump命令,指定显示数据链路层头部、不转换协议和端口号、以绝对值显示包的INS序列号、以十六进制和ASCII显示数据包  
    第二行:提示使用选项-v和-vv,可以看到更全的输出内容
    第三行:监听通过eth0这个NIC设备的网络包,且它的链路层是基于以太网的,要抓的包大小限制是96字节
    第四行:11:18:40.804021 表示抓包的时、分、秒、微秒;00:22:64:2d:35:1c > 00:0c:29:85:0b:14 表示从mac地址发送到mac地址的主机;ethertype IPv4 (0x0800) 表示Ethernet帧的协议类型为ipv4(即代码为0x0800)
    第五行:length 74 表示以太帧长度为66;192.168.3.43.57889 > 192.168.2.222.8080 表示从ip的端口发送到ip的端口,>标识传输方向; S 建立连接的连接标识;1808454045:1808454045(0) 表示包的顺序号是768512且没有数据,格式为 first:last(n bytes),即包中数据的是从顺序号first开始直到last结束的不包括last的n个字节的用户数据;
    第六行:win 5840 表示窗口大小为5840字节;mss 1460 表示由发送端指明的最大报文段长度,发送端将不接收超过这个长度的TCP报文段;sackOK 表示发送端支持并同意使用SACK选择性确认技术;nop是一个空操作选项, wscale 7 表示发送端使用的窗口扩大因子为7 

    注:TCP连接标识有 SYN(建立连接)、FIN(关闭连接)、ACK(响应确认)、PSH(数据推送)、RST(连接重置)、URG(紧急置位),当出现SYN和SYN+ACK包时表示客户端与服务器端建立了一个连接,当出现PSH包时表示有DATA数据包被传递,当出现FIN包或RST包时表示客户端与服务器端断开了连接


五、使用举例

# 抓取所有和主机192.168.3.43通信的包含发送给和接收到的数据包
[root@xl usr]# tcpdump host 192.168.3.43
# 抓取所有与本机的tcp 80端口通信的数据包
[root@xl usr]# tcpdump udp port 80
# 抓取所有在eth0网络接口上发送给主机192.168.3.43的数据包
[root@xl usr]# tcpdump -i eth0 dst host 192.168.3.43
# 抓取与主机192.168.3.43的80端口通信的数据包
[root@xl usr]# tcpdump -i eth0 host 192.168.3.43 and port 80
# 抓取主机192.168.2.222和主机192.168.3.43之外的所有主机通信的ip包并写入文件
[root@xl usr]# tcpdump ip host 192.168.2.222 and ! 192.168.3.43 -w ./target.cap



这篇关于Linux - Tcpdump命令的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1140676

相关文章

kali linux 无法登录root的问题及解决方法

《kalilinux无法登录root的问题及解决方法》:本文主要介绍kalilinux无法登录root的问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,... 目录kali linux 无法登录root1、问题描述1.1、本地登录root1.2、ssh远程登录root2、

Linux ls命令操作详解

《Linuxls命令操作详解》通过ls命令,我们可以查看指定目录下的文件和子目录,并结合不同的选项获取详细的文件信息,如权限、大小、修改时间等,:本文主要介绍Linuxls命令详解,需要的朋友可... 目录1. 命令简介2. 命令的基本语法和用法2.1 语法格式2.2 使用示例2.2.1 列出当前目录下的文

Spring Boot项目部署命令java -jar的各种参数及作用详解

《SpringBoot项目部署命令java-jar的各种参数及作用详解》:本文主要介绍SpringBoot项目部署命令java-jar的各种参数及作用的相关资料,包括设置内存大小、垃圾回收... 目录前言一、基础命令结构二、常见的 Java 命令参数1. 设置内存大小2. 配置垃圾回收器3. 配置线程栈大小

Linux中的计划任务(crontab)使用方式

《Linux中的计划任务(crontab)使用方式》:本文主要介绍Linux中的计划任务(crontab)使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、前言1、linux的起源与发展2、什么是计划任务(crontab)二、crontab基础1、cro

Linux换行符的使用方法详解

《Linux换行符的使用方法详解》本文介绍了Linux中常用的换行符LF及其在文件中的表示,展示了如何使用sed命令替换换行符,并列举了与换行符处理相关的Linux命令,通过代码讲解的非常详细,需要的... 目录简介检测文件中的换行符使用 cat -A 查看换行符使用 od -c 检查字符换行符格式转换将

Linux系统配置NAT网络模式的详细步骤(附图文)

《Linux系统配置NAT网络模式的详细步骤(附图文)》本文详细指导如何在VMware环境下配置NAT网络模式,包括设置主机和虚拟机的IP地址、网关,以及针对Linux和Windows系统的具体步骤,... 目录一、配置NAT网络模式二、设置虚拟机交换机网关2.1 打开虚拟机2.2 管理员授权2.3 设置子

Linux系统中卸载与安装JDK的详细教程

《Linux系统中卸载与安装JDK的详细教程》本文详细介绍了如何在Linux系统中通过Xshell和Xftp工具连接与传输文件,然后进行JDK的安装与卸载,安装步骤包括连接Linux、传输JDK安装包... 目录1、卸载1.1 linux删除自带的JDK1.2 Linux上卸载自己安装的JDK2、安装2.1

Linux卸载自带jdk并安装新jdk版本的图文教程

《Linux卸载自带jdk并安装新jdk版本的图文教程》在Linux系统中,有时需要卸载预装的OpenJDK并安装特定版本的JDK,例如JDK1.8,所以本文给大家详细介绍了Linux卸载自带jdk并... 目录Ⅰ、卸载自带jdkⅡ、安装新版jdkⅠ、卸载自带jdk1、输入命令查看旧jdkrpm -qa

Linux samba共享慢的原因及解决方案

《Linuxsamba共享慢的原因及解决方案》:本文主要介绍Linuxsamba共享慢的原因及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux samba共享慢原因及解决问题表现原因解决办法总结Linandroidux samba共享慢原因及解决

新特性抢先看! Ubuntu 25.04 Beta 发布:Linux 6.14 内核

《新特性抢先看!Ubuntu25.04Beta发布:Linux6.14内核》Canonical公司近日发布了Ubuntu25.04Beta版,这一版本被赋予了一个活泼的代号——“Plu... Canonical 昨日(3 月 27 日)放出了 Beta 版 Ubuntu 25.04 系统镜像,代号“Pluc