【Linux常用命令】tcpdump使用讲解

tcpdump 命令介绍

tcpdump 用简单的语言概括就是dump the traffic on a network,是linux环境下抓包工具,可以将网络中传输的数据包的“包头”全部捕获过来进程分析,其支持网络层、特定的传输协议、数据发送和接收的主机、网卡和端口的过滤,并提供and、or、not等语句进行逻辑组合捕获数据包或去掉不用的信息。也可以对对应网络接口流量进行抓取或者过滤抓取并打印输出到屏幕,也可以保存到指定文件。指定的文件可以用wireshark来打开查看。方便我们确定网络问题

1.语法

tcpdump语法:
tcpdump [ -adeflnNOpqStvx ] [ -c 数量 ] [ -F 文件名 ]
               [ -i 网络接口 ] [ -r 文件名] [ -s snaplen ]
               [ -T 类型 ] [ -w 文件名 ] [表达式 ]

2.参数介绍

# 常规参数介绍:
 
 -A 以ASCII格式打印出所有分组,并将链路层的头最小化。
 
-c 在收到指定的数量的分组后,tcpdump就会停止。
 
-C 在将一个原始分组写入文件之前,检查文件当前的大小是否超过了参数file_size 中指定的大小。如果超过了指定大小,则关闭当前文件,然后在打开一个新的文件。参数 file_size 的单位是兆字节(是1,000,000字节,而不是1,048,576字节)。
 
-d 将匹配信息包的代码以人们能够理解的汇编格式给出。
 
-dd 将匹配信息包的代码以c语言程序段的格式给出。
 
-ddd 将匹配信息包的代码以十进制的形式给出。
 
-D 打印出系统中所有可以用tcpdump截包的网络接口。
 
-e 在输出行打印出数据链路层的头部信息。
 
-E 用spi@ipaddr algo:secret解密那些以addr作为地址,并且包含了安全参数索引值spi的IPsec ESP分组。
 
-f 将外部的Internet地址以数字的形式打印出来。
 
-F 从指定的文件中读取表达式,忽略命令行中给出的表达式。
 
-i 指定监听的网络接口。
 
-l 使标准输出变为缓冲行形式,可以把数据导出到文件。
 
-L 列出网络接口的已知数据链路。
 
-m 从文件module中导入SMI MIB模块定义。该参数可以被使用多次,以导入多个MIB模块。
 
-M 如果tcp报文中存在TCP-MD5选项,则需要用secret作为共享的验证码用于验证TCP-MD5选选项摘要(详情可参考RFC 2385)。
 
-b 在数据-链路层上选择协议,包括ip、arp、rarp、ipx都是这一层的。
 
-n 不把网络地址转换成名字。
 
-nn 不进行端口名称的转换。
 
-N 不输出主机名中的域名部分。例如,‘nic.ddn.mil‘只输出’nic‘。
 
-t 在输出的每一行不打印时间戳。
 
-O 不运行分组分组匹配(packet-matching)代码优化程序。
 
-P 不将网络接口设置成混杂模式。
 
-q 快速输出。只输出较少的协议信息。
 
-r 从指定的文件中读取包(这些包一般通过-w选项产生)-S 将tcp的序列号以绝对值形式输出,而不是相对值。
 
-s 从每个分组中读取最开始的snaplen个字节,而不是默认的68个字节。
 
-T 将监听到的包直接解释为指定的类型的报文,常见的类型有rpc远程过程调用)和snmp(简单网络管理协议;)。
 
-t 不在每一行中输出时间戳。
 
-tt 在每一行中输出非格式化的时间戳。
 
-ttt 输出本行和前面一行之间的时间差。
 
-tttt 在每一行中输出由date处理的默认格式的时间戳。
 
-u 输出未解码的NFS句柄。
 
-v 输出一个稍微详细的信息,例如在ip包中可以包括ttl和服务类型的信息。
 
-vv 输出详细的报文信息。
 
-w 直接将分组写入文件中,而不是不分析并打印出来。 

3.tcpdump应用案例

1、想要截获所有210.27.48.1 的主机收到的和发出的所有的数据包:
[root@dodo ~]# tcpdump host 210.27.48.1

2、想要截获主机210.27.48.1 和主机210.27.48.2 或210.27.48.3的通信,使用命令
[root@dodo ~]# tcpdump host 210.27.48.1 and (210.27.48.2 or 210.27.48.3)

3、如果想要获取主机210.27.48.1除了和主机210.27.48.2之外所有主机通信的ip包,使用命令:
[root@dodo ~]# tcpdump ip host 210.27.48.1 and ! 210.27.48.2

4、如果想要获取主机210.27.48.1接收或发出的telnet包,使用如下命令:
[root@dodo ~]# tcpdump tcp port 23 host 210.27.48.1

5、通过服务端口抓包查看
tcpdump –i eth0 –nn –tttt –vvAls0 port 8003

-i: 指定监听的网卡
-nn: 不转化主机名和端口名,直接用数字
-tttt: 每行加上易读的时间戳
-vv: 详细输出
-A: 用ASCII打印每一个包
-l: 标准输出使用行缓存,结合grep等命令时有用
-s: 设置每个包抓取的长度,使用0表示尽可能多的(默认262144字节)

  • 5
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值