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



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值