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

相关文章

VScode连接远程Linux服务器环境配置图文教程

《VScode连接远程Linux服务器环境配置图文教程》:本文主要介绍如何安装和配置VSCode,包括安装步骤、环境配置(如汉化包、远程SSH连接)、语言包安装(如C/C++插件)等,文中给出了详... 目录一、安装vscode二、环境配置1.中文汉化包2.安装remote-ssh,用于远程连接2.1安装2

Redis的Zset类型及相关命令详细讲解

《Redis的Zset类型及相关命令详细讲解》:本文主要介绍Redis的Zset类型及相关命令的相关资料,有序集合Zset是一种Redis数据结构,它类似于集合Set,但每个元素都有一个关联的分数... 目录Zset简介ZADDZCARDZCOUNTZRANGEZREVRANGEZRANGEBYSCOREZ

Linux中shell解析脚本的通配符、元字符、转义符说明

《Linux中shell解析脚本的通配符、元字符、转义符说明》:本文主要介绍shell通配符、元字符、转义符以及shell解析脚本的过程,通配符用于路径扩展,元字符用于多命令分割,转义符用于将特殊... 目录一、linux shell通配符(wildcard)二、shell元字符(特殊字符 Meta)三、s

Linux之软件包管理器yum详解

《Linux之软件包管理器yum详解》文章介绍了现代类Unix操作系统中软件包管理和包存储库的工作原理,以及如何使用包管理器如yum来安装、更新和卸载软件,文章还介绍了如何配置yum源,更新系统软件包... 目录软件包yumyum语法yum常用命令yum源配置文件介绍更新yum源查看已经安装软件的方法总结软

linux报错INFO:task xxxxxx:634 blocked for more than 120 seconds.三种解决方式

《linux报错INFO:taskxxxxxx:634blockedformorethan120seconds.三种解决方式》文章描述了一个Linux最小系统运行时出现的“hung_ta... 目录1.问题描述2.解决办法2.1 缩小文件系统缓存大小2.2 修改系统IO调度策略2.3 取消120秒时间限制3

Linux alias的三种使用场景方式

《Linuxalias的三种使用场景方式》文章介绍了Linux中`alias`命令的三种使用场景:临时别名、用户级别别名和系统级别别名,临时别名仅在当前终端有效,用户级别别名在当前用户下所有终端有效... 目录linux alias三种使用场景一次性适用于当前用户全局生效,所有用户都可调用删除总结Linux

Linux:alias如何设置永久生效

《Linux:alias如何设置永久生效》在Linux中设置别名永久生效的步骤包括:在/root/.bashrc文件中配置别名,保存并退出,然后使用source命令(或点命令)使配置立即生效,这样,别... 目录linux:alias设置永久生效步骤保存退出后功能总结Linux:alias设置永久生效步骤

Linux使用fdisk进行磁盘的相关操作

《Linux使用fdisk进行磁盘的相关操作》fdisk命令是Linux中用于管理磁盘分区的强大文本实用程序,这篇文章主要为大家详细介绍了如何使用fdisk进行磁盘的相关操作,需要的可以了解下... 目录简介基本语法示例用法列出所有分区查看指定磁盘的区分管理指定的磁盘进入交互式模式创建一个新的分区删除一个存

Linux使用dd命令来复制和转换数据的操作方法

《Linux使用dd命令来复制和转换数据的操作方法》Linux中的dd命令是一个功能强大的数据复制和转换实用程序,它以较低级别运行,通常用于创建可启动的USB驱动器、克隆磁盘和生成随机数据等任务,本文... 目录简介功能和能力语法常用选项示例用法基础用法创建可启动www.chinasem.cn的 USB 驱动

关于Maven生命周期相关命令演示

《关于Maven生命周期相关命令演示》Maven的生命周期分为Clean、Default和Site三个主要阶段,每个阶段包含多个关键步骤,如清理、编译、测试、打包等,通过执行相应的Maven命令,可以... 目录1. Maven 生命周期概述1.1 Clean Lifecycle1.2 Default Li