linux之tcpdump抓包工具

linux之tcpdump抓包工具

  • tcpdump简介
  • tcpdump的使用及命令格式
    • tcpdump的选项介绍
    • 表达式
    • 七层网络协议
    • TCP/UDP协议
    • tcpdump抓包
      • 1. 列出可以抓包的网络接口
      • 2. 监视指定网络接口的数据包
      • 3. 监视指定主机的数据包
      • 4. 打印test和test1或test和test2之间通信的数据包
      • 5. 打印test与其他主机之间通信的IP数据包,但是不包括与test2之间的数据包
      • 6. 截获主机test发送的所有数据包
      • 7. 监视所有发送到主机test1的数据包
      • 8. 监视指定主机和端口的数据包
      • 9. 监视指定网络的数据包
      • 10. 抓取ping包
      • 11. 抓取本机的80端口号
      • 12. 解析包数据
      • 13. 抓取指定端口范围的流量
      • 14. 抓取指定网段的流量
      • 15. 抓取ens160网卡上所有的arp数据包
      • 16. 抓取指定客户端访问 ssh 的数据包
      • 17. 抓取从某个网段来,到某个网段去的流量
      • 18. 抓取来自某个主机,发往非 ssh 端口的流量

tcpdump简介

  • linux作为网络服务器,特别事作为路由器和网关时,数据的采集和分析时不可少的。tcpdump时linux中强大的网络数据采集分析工具之一。
  • 用简单的话来定义tcpdump就是:dump the traffic on a network,根据使用者的定义对网络上的数据包进行截获的包分析工具。
  • 作为互联网上的经典的系统管理员必备工具,tcpdump以其强大的功能,灵活的截取策略,成为每个高级的系统管理员分析网络,排查问题等所必备的工具之一。
  • tcpdump的总结输出格式为:系统时间 来源主机 端口 > 目标端口.端口 数据包参数

tcpdump的使用及命令格式

tcpdump采用命令行方式,它的命令格式为:
tcpdump [ -adeflnNOpqStvx ] [ -c 数量 ] [ -F 文件名 ]

[ -i 网络接口 ] [ -r 文件名] [ -s snaplen ]

[ -T 类型 ] [ -w 文件名 ] [表达式]

tcpdump的选项介绍

-a 将网络地址和广播地址转变成名字
-d 将匹配信息包的代码以人们能够理解的汇编格式给出;
-dd 将匹配信息包的代码以C语言程序段的格式给出;
-ddd 将匹配信息包的代码以十进制的形式给出;
-q 快速打印输出。即打印很少的协议相关信息,从而输出行都比较简短。
-X 输出包的头部数据,会以16进制和ASCII两种方式同时输出。
-XX 输出包的头部数据,会以16进制和ASCII两种方式同时输出,更详细。
-D 列出可用于抓包的接口。将会列出接口的数值编号和接口名,它们都可以用于"-i"后。
-e 在输出行打印出数据链路层的头部信息;
-f 将外部的internet地址以数字的形式打印出来;
-l 使标准输出变为缓冲行形式;
-n 对地址以数字方式显式,否则显式为主机名,也就是说-n选项不做主机名解析;
-nn 除了-n的作用外,还把端口显示为数值,否则显示端口服务名。
-t 在输出的每一行不打印时间戳;
-v 输出一个稍微详细的信息,例如在IP包中可以包括ttl和服务类型的信息;
-P 指定要抓取的包是流入还是流出的包。可以给定的值为"in"、“out"和"inout”,默认为"inout"
-v 当分析和打印的时候,产生详细的输出。
-vv 输出详细的报文信息;
-vvv 产生比-vv更详细的输出。
-c 在收到指定的包的数目后,tcpdump就会停止;
-F 从指定的文件中读取表达式,忽略其它的表达式;
-i 指定监听的网络接口;
-r 从指定的文件中读取包(这些包一般通过-w选项产生);
-w 直接将包写入文件中,并不分析和打印出来;
-T  将监听到的包直接解释为指定的类型的报文,常见的类型有rpc (远程过程调用)和snmp(简单 网络管理协议)

表达式

  • 类型
    host,net,port,portrange
    例如:host 192.168.182.142,net 128.3,port 80,portrange 6000-6008

  • 目标
    src,dst,src or dst,src and dst

  • 协议
    tcp,udp,icmp,ip,ether,ip6,arp若不给协议,则默认匹配所有可能的类型

表达式之间可以使用修饰符 “and / && / or || / not / ! “等进行连接组成复杂的表达式来完成更复杂的工作;使用”()“可以用来表示优先级的高低,但是()会被shell解释成其他意思,必要的时候需要使用(反斜杠来进行转义),需要的时候也可以用引号将其引起来:”()”

在使用tcpdump之前我们需要先了解OSI七层网络协议及各层的作用

七层网络协议

从下往上依次是: 物理层、数据链路层、网络层、传输层、会话层、表示层、应用层
OSI层数 作用 协议
应用层 文件传输,电子邮件,文件服务,虚拟终端 http,ftp,DNS,SNMP,telnet,TFTP,SMTP
表示层 数据格式化,定义数据格式及数据加密 无协议
会话层 解除或建立与其他接点的联系 无协议
传输层 提供端对端的接口 TCP,UDP
网络层 为数据包选择路由 IP,icmp,RIP,OSPF,BGP
数据链路层 传输有地址的帧,错误检测功能 PPP,ARP,RARP等
物理层 以二进制数据形式在物理媒体上传输数据 ISO2110,802.3,IEEE802

TCP/UDP协议

TCP和UDP属于传输层的协议类型。TCP提供IP环境下的数据可靠传输,它提供的服务包括数据流传送、可靠性、有效流控、全双工操作和多路复用。通过面向连接、端到端和可靠的数据包发送。通俗说,它是事先为所要发送的数据包开辟好通道,然后再进行数据的发送;而UDP则不为IP提供可靠性、流控或差错恢复功能。TCP一般用于对数据安全或数据完整性要求较高的应用;而UDP则是用于数据可靠性要求较低,数据传输快的应用。TCP支持的协议有:telnet、FTP、SMTP等;UDP支持NFS(网络文件系统)、SNMP(简单网络管理协议)、DNS(域名解析)、TFTP(通用文件传输协议)等
TCP/IP协议与底层的物理和数据链路等无关

tcpdump抓包

1. 列出可以抓包的网络接口

tcpdump需要使用root用户的权限
[root@192 ~]# tcpdump -D
1.ens160 [Up, Running]
2.lo [Up, Running, Loopback]
3.any (Pseudo-device that captures on all interfaces) [Up, Running]
4.bluetooth-monitor (Bluetooth Linux Monitor) [none]
5.nflog (Linux netfilter log (NFLOG) interface) [none]
6.nfqueue (Linux netfilter queue (NFQUEUE) interface) [none]
7.usbmon0 (All USB buses) [none]
8.usbmon1 (USB bus number 1)
9.usbmon2 (USB bus number 2)

2. 监视指定网络接口的数据包

[root@192 ~]# tcpdump -i ens160

3. 监视指定主机的数据包

// host 后面可以接主机名或者IP地址,但是主机名为localhost不可以
[root@test ~]# tcpdump -i ens160 host test

4. 打印test和test1或test和test2之间通信的数据包

[root@test ~]# tcpdump -i ens160 host test and \(test1 or test2\)

5. 打印test与其他主机之间通信的IP数据包,但是不包括与test2之间的数据包

[root@test ~]# tcpdump -i ens160 host test and not test2

6. 截获主机test发送的所有数据包

// src表示数据包来自的地方成为源
[root@test ~]# tcpdump -i ens160 src host test

7. 监视所有发送到主机test1的数据包

// dst表示数据包去的目的地
[root@test ~]# tcpdump -i ens160 dst host test1

8. 监视指定主机和端口的数据包

[root@test ~]# tcpdump -i ens160 port 3306 and host test1

9. 监视指定网络的数据包

// 表示的是本机与192.168网段间通信的数据包,-c 5 表示只抓取5个包
[root@test ~]# tcpdump -i ens160 -c 5 net 192.168

10. 抓取ping包

[root@test ~]# tcpdump -c 5 -nn -i ens160

11. 抓取本机的80端口号

[root@test ~]# tcpdump -v -c 5 -nn -i ens160 tcp dst port 80

12. 解析包数据

[root@test ~]# tcpdump -c 5 -q -XX -vvv -nn -i ens160 tcp dst port 3306

13. 抓取指定端口范围的流量

[root@test ~]# tcpdump -ni ens160 portrange 80-10051

14. 抓取指定网段的流量

[root@test ~]# tcpdump -ni ens160 net 192.168.1.0/24

15. 抓取ens160网卡上所有的arp数据包

[root@test ~]# tcpdump -ni ens160 arp

16. 抓取指定客户端访问 ssh 的数据包

[root@test ~]# tcpdump -v -ni ens160 src 192.168.182.142 and dst port 22

17. 抓取从某个网段来,到某个网段去的流量

[root@test ~]# tcpdump -ni ens160 net 192.168.1.0/24 and dst net 100.0.0.0/8 or 172.16.0.0/16

18. 抓取来自某个主机,发往非 ssh 端口的流量

[root@test ~]# tcpdump -ni ens160 src 172.16.0.0 and not dst port 22

你可能感兴趣的:(网络专栏,linux,tcpdump,网络,运维,抓包)