第一种是关于类型的关键字,主要包括host,net,port,例如host 172.88.23.45指明172.88.23.45是一台主机,net 255.0.0.0指明255.0.0.0是一个网络地址,port23指明端口是23,如果没有指定类型,缺省的类型是host

第二种是确定传输方向的关键字,主要包括src,dst,这些关键字执行了传输的方向,例如src 172.88.23.45 ,指明ip包中源地址为172.88.23.45,dst net 255.0.0.0指明目的网络地址是255.0.0.0,如果没有指明方向关键字,则缺省是srcordst关键字

第三种是协议关键字,主要包括fddi,ip,arp,rarp,udp等类型,fddi是ether的别名,fddi和ether具有类似的源地址和目的地址,所以可以讲fddi协议包当做ether的包进行处理和分析。其他的几个关键字就是指明了监听的包的协议内容,如果没有指定任何协议,tcpdump将会监听所有协议的信息包

除了三种类型的关键字外,其他重要的关键字如下,gateway,broadcast,less,greater,还有三种逻辑运算,取非运算是not和!,与运算时and和&&,或运算时or和||,这些关键字可以组合起来构成强大的组合条件来满足人们的需要

直接启动tcpdump将监视第一个网卡

使用参数-i可以指定tcpduam要监视的网卡,服务器有多个网卡的时候可以使用

使用-c 指定要监听的数据包的数量

使用-w 指定将监听到的内容写入文件中保存

实例:截获172.88.23.45主机收到和发出的所有的数据包

tcpdump host 172.88.23.45

截获172.88.23.45主机和截获172.88.23.46或172.88.23.47的通信

tcpdump host 172.88.23.45 and \(172.88.23.45 or 172.88.23.47\)

截获172.88.23.45主机除了和172.88.23.46的通信

tcpdump ip host 172.88.23.45 and !172.88.23.45

截获主机172.88.23.45接受或发出的telnet包,使用如下命令

tcpdump tcp port 23 host 172.88.23.45

对172.88.23.45主机的udp 123端口进行监听,123为ntp的服务器端口

tcpdump udp port 123

如果我们只需要列出送到80端口的数据包,用dst port

tcpdump -i eth0 hostname and dst port 80 目的端口是80

tcpdump对获取的数据并没有进行彻底解码,数据包内的大部分内容是使用十六进制的形式直接打印输出的,这不利于分析网络故障,通常的解决办法是先使用-w参数对获取到的数据文件进行保存,然后使用其他程序进行解码分析。