tcpdump命令:
1、指定接口(-i)
    tcpdump -i eth0
2、指定ip地址(host),可以辅加and,or,!等逻辑符,以及src,dest等表示方向。
三次握手过程分析
    在主机A上开启SSHD服务,此时不要有任何客户端主机来连接主机A的SSHD服务,这样是为了抓包更清楚。
主机A执行:tcpdump port 22 -c 3 -n -S
#打印序列号 -S     Print absolute, rather than relative, TCP sequence numbers.
#port 端口号
-c 抓几个包
-n 不解析端口号为协议名
主机B执行:yum install telnet -y #安装telnet
telnet 192.168.1.23 22 #连接主机A的22端口                             
[root@zq ~]# tcpdump -h
tcpdump version 4.1-PRE-CVS_2012_02_01
libpcap version 1.4.0
Usage: tcpdump [-aAdDefIKlLnNOpqRStuUvxX] [ -B size ] [ -c count ]
        [ -C file_size ] [ -E algo:secret ] [ -F file ] [ -G seconds ]
        [ -i interface ] [ -M secret ] [ -r file ]
        [ -s snaplen ] [ -T type ] [ -w file ] [ -W filecount ]
        [ -y datalinktype ] [ -z command ] [ -Z user ]
        [ expression ]
eg:
[root@zq ~]# tcpdump port 22 -c 3 -n -S
tcpdump: verbose output suppressed, use -v or -vv for full protocol decode
listening on eth0, link-type EN10MB (Ethernet), capture size 65535 bytes
21:18:05.554990 IP 192.168.1.100.61883 > 192.168.1.23.ssh: Flags [S], seq 919487421, win 8192, options [mss 1460,nop,wscale 8,nop,nop,sackOK], length 0
21:18:05.555081 IP 192.168.1.23.ssh > 192.168.1.100.61883: Flags [S.], seq 281122195, ack 919487422, win 14600, options [mss 1460,nop,nop,sackOK,nop,wscale 6], length 0
21:18:05.555379 IP 192.168.1.100.61883 > 192.168.1.23.ssh: Flags [.], ack 281122196, win 256, length 0
3 packets captured
3 packets received by filter
0 packets dropped by kernel
tshark -w filename -i eth0 -q
-w    将抓包的数据写入文件filename中
-i    指定要抓包的接口名称
tshark -r filename
-r 指定要读取的包文件
-V 将包尽可能的解析(这个有时在包数量很多的情况下可以不使用,这样它会给出一个很简洁的报文解释)