压在透明的玻璃上c-国产精品国产一级A片精品免费-国产精品视频网-成人黄网站18秘 免费看|www.tcsft.com

tcpdump的用法詳解

  tcpdump采用命令行方式,它的命令格式為:

  tcpdump [ -adeflnNOpqStvx ] [ -c 數量 ] [ -F 文件名 ]

  [ -i 網絡接口 ] [ -r 文件名] [ -s snaplen ]

  [ -T 類型 ] [ -w 文件名 ] [表達式 ]

  (1). tcpdump的選項介紹

  -a    將網絡地址和廣播地址轉變成名字;

  -d    將匹配信息包的代碼以人們能夠理解的匯編格式給出;

  -dd    將匹配信息包的代碼以c語言程序段的格式給出;

  -ddd   將匹配信息包的代碼以十進制的形式給出;

  -e    在輸出行打印出數據鏈路層的頭部信息;

  -f    將外部的Internet地址以數字的形式打印出來;

  -l    使標準輸出變為緩沖行形式;

  -n    不把網絡地址轉換成名字;

  -t    在輸出的每一行不打印時間戳;

  -v    輸出一個稍微詳細的信息,例如在ip包中可以包括ttl和服務類型的信息;

  -vv    輸出詳細的報文信息;

  -c    在收到指定的包的數目后,tcpdump就會停止;

  -F    從指定的文件中讀取表達式,忽略其它的表達式;

  -i    指定監聽的網絡接口;

  -r    從指定的文件中讀取包(這些包一般通過-w選項產生);

  -w    直接將包寫入文件中,并不分析和打印出來;

  -T    將監聽到的包直接解釋為指定的類型的報文,常見的類型有rpc (遠程過程調用)和snmp(簡單網絡管理協議;)

  (2). tcpdump的表達式介紹 

    表達式是一個正則表達式,tcpdump利用它作為過濾報文的條件,如果一個報文滿足表達式的條件,則這個報文將會被捕獲。如果沒有給出任何條件,則網絡上所有的信息包將會被截獲。在表達式中一般如下幾種類型的關鍵字。

  第一種是關于類型的關鍵字,主要包括host,net,port, 例如 host 210.27.48.2,指明210.27.48.2是一臺主機,net 202.0.0.0 指明 202.0.0.0是一個網絡地址,port 23指明端口號是23。如果沒有指定類型,缺省的類型是host.

  第二種是確定傳輸方向的關鍵字,主要包括src , dst ,dst or src, dst and src,這些關鍵字指明了傳輸的方向。舉例說明,src 210.27.48.2 ,指明ip包中源地址是210.27.48.2 , dst net202.0.0.0 指明目的網絡地址是202.0.0.0 。如果沒有指明方向關鍵字,則缺省是src or dst關鍵字。

  第三種是協議的關鍵字,主要包括fddi,ip,arp,rarp,tcp,udp等類型。Fddi指明是在FDDI(分布式光纖數據接口網絡)上的特定的網絡協議,實際上它是"ether"的別名,fddi和ether具有類似的源地址和目的地址,所以可以將fddi協議包當作ether的包進行處理和分析。其他的幾個關鍵字就是指明了監聽的包的協議內容。如果沒有指定任何協議,則tcpdump將會監聽所有協議的信息包。

  除了這三種類型的關鍵字之外,其他重要的關鍵字如下:gateway,broadcast,less,greater,還有三種邏輯運算,取非運算是 'not ' '! ',與運算是'and','&&';或運算 是'or','││';這些關鍵字可以組合起來構成強大的組合條件來滿足人們的需要,下面舉幾個例子來說明。

  實戰:

  A想要截獲所有210.27.48.1 的主機收到的和發出的所有的數據包:

  關于類型的關鍵字,主要包括host,net,port,

  #tcpdump host 210.27.48.1

  B想要截獲主機210.27.48.1 和主機210.27.48.2 或210.27.48.3的通信,使用命令:(在命令行中使用括號時,一定要添加''  轉義字符)

  #tcpdump host 210.27.48.1 and (210.27.48.2 or 210.27.48.3 )

  C如果想要獲取主機210.27.48.1除了和主機210.27.48.2之外所有主機通信的ip包,使用命令:

  協議的關鍵字,主要包括fddi,ip,arp,rarp,tcp,udp等類型。

  #tcpdump ip host 210.27.48.1 and ! 210.27.48.2

  D如果想要獲取主機210.27.48.1接收或發出的telnet包,使用如下命令:

  #tcpdump tcp port 23 host 210.27.48.1

  E 對本機的udp 123 端口進行監視 123 為ntp的服務端口

  # tcpdump udp port 123

  F 系統將只對名為hostname的主機的通信數據包進行監視。主機名可以是本地主機,也可以是網絡上的任何一臺計算機。下面的命令可以讀取主機hostname發送的所有數據:

  #tcpdump -i eth0 src host hostname

  G 下面的命令可以監視所有送到主機hostname的數據包:

  #tcpdump -i eth0 dst host hostname

  H 我們還可以監視通過指定網關的數據包:

  #tcpdump -i eth0 gateway Gatewayname

  I 如果你還想監視編址到指定端口的TCP或UDP數據包,那么執行以下命令:

  #tcpdump -i eth0 host hostname and port 80

  J 如果想要獲取主機210.27.48.1除了和主機210.27.48.2之外所有主機通信的ip包,使用命令:

  #tcpdump ip host 210.27.48.1 and ! 210.27.48.2

  K 想要截獲主機210.27.48.1 和主機210.27.48.2 或210.27.48.3的通信,使用命令:

  #tcpdump host 210.27.48.1 and (210.27.48.2 or 210.27.48.3 )

  L 如果想要獲取主機210.27.48.1除了和主機210.27.48.2之外所有主機通信的ip包,使用命令:

  #tcpdump ip host 210.27.48.1 and ! 210.27.48.2

  M 如果想要獲取主機210.27.48.1接收或發出的telnet包,使用如下命令:

  #tcpdump tcp port 23 host 210.27.48.1

  Ps:也就是通過端口號來監聽,23默認是telnet的端口號,像其他服務ssh www ftp 等我們也可以這樣進行操作

  (3). tcpdump的輸出結果介紹

  下面我們介紹幾種典型的tcpdump命令的輸出信息

  A,數據鏈路層頭信息

  -e    在輸出行打印出數據鏈路層的頭部信息;

  使用命令: #tcpdump –e host ice

  ice 是一臺裝有linux的主機,她的MAC地址是0:90:27:58:AF:1A

  H219是一臺裝有SOLARIC的SUN工作站,它的MAC地址是8:0:20:79:5B:46;上一條命令的輸出結果如下所示:

  21:50:12.847509 eth0 < 8:0:20:79:5b:46 0:90:27:58:af:1a ip 60: h219.33357 > ice.telne

  t 0:0(0) ack 22535 win 8760 (DF)

  分析:21:50:12是顯示的時間, 847509是ID號,eth0 <表示從網絡接口eth0 接受該數據包,eth0>表示從網絡接口設備發送數據包, 8:0:20:79:5b:46是主機H219的MAC地址,它表明是從源地址H219發來的數據包.

  0:90:27:58:af:1a是主機ICE的MAC地址,表示該數據包的目的地址是ICE . ip 是表明該數據包是IP數據包,60是數據包的長度, h219.33357 > ice.telnet表明該數據包是從主機H219的33357端口發往主機ICE的TELNET(23)端口. ack 22535表明對序列號是222535的包進行響應. win 8760表明發送窗口的大小是8760.

  B,ARP包的TCPDUMP輸出信息

  使用命令:#tcpdump arp

  得到的輸出結果是:

  22:32:42.802509 eth0 > arp who-has route tell ice

  時間.ID 端口> arp請求包 誰有route的mac地址

  (0:90:27:58:af:1a)

  22:32:42.802902 eth0 < arp reply route is-at 0:90:27:12:10:66 (0:90:27:58:af:1a)

  分析: 22:32:42是時間戳, 802509是ID號, eth0 >表明從主機發出該數據包, arp表明是ARP請求包,who-has route tell ice表明是主機ICE請求主機ROUTE的MAC地址。0:90:27:58:af:1a是主機ICE的MAC地址。

  C,TCP包的輸出信息

  用TCPDUMP捕獲的TCP包的一般輸出信息是:

  src > dst: flags data-seqno ack window urgent options

  src> dst:表明從源地址到目的地址, flags是TCP包中的標志信息,S 是SYN標志, F (FIN), P (PUSH) , R(RST) "." (沒有標記); data-seqno是數據包中的數據的順序號, ack是下次期望的順序號,window是接收緩存的窗口大小, urgent表明數據包中是否有緊急指針. Options是選項.

  D,UDP包的輸出信息

  用TCPDUMP捕獲的UDP包的一般輸出信息是:

  route.port1 > ice.port2: udp lenth

  UDP十分簡單,上面的輸出行表明從主機ROUTE的port1端口發出的一個UDP數據包到主機ICE的port2端口,類型是UDP, 包的長度是lenth

  輔助工具

  (1) 想查看TCP或者UDP端口使用情況,使用 netstat -anp

  如果有些進程看不見,如只顯示”-”,可以嘗試

  sudo netstat -anp

  如果想看某個端口的信息,使用lsof命令,如:

  sudo lsof -i :631

  -bash-3.00# netstat -tln

  netstat -tln 命令是用來查看linux的端口使用情況

  /etc/init.d/vsftp start 是用來啟動ftp端口~!

  看文件/etc/services

  netstat

  查看已經連接的服務端口(ESTABLISHED)

  netstat -a

  查看所有的服務端口(LISTEN,ESTABLISHED)

  sudo netstat -ap

  查看所有 的服務端口并顯示對應的服務程序名

  nmap <掃描類型><掃描參數>

  例如:

  nmap localhost

  nmap -p 1024-65535 localhost

  nmap -PT 192.168.1.127-245

  當我們使用 netstat -apn 查看網絡連接的時候,會發現很多類似下面的內容:

  Proto Recv-Q Send-Q Local Address Foreign Address State PID/Program name

  tcp 0 52 218.104.81.152:7710 211.100.39.250:29488 ESTABLISHED 6111/1

  顯示這臺服務器開放了7710端口,那么 這個端口屬于哪個程序呢?我們可以使用 lsof -i :7710 命令來查詢:

  COMMAND PID USER FD TYPE DEVICE SIZE NODE NAME

  sshd 1990 root 3u IPv4 4836 TCP *:7710 (LISTEN)

  這樣,我們就知道了7710端口是屬于sshd程序的。

  (2) 運行tcpdump命令出現錯誤信息排除

  tcpdump: no suitable device found

  tcpdump: no devices found /dev/bpf4: A file or directory in the path name does not exist.

  解決方案 2種原因:

  1.權限不夠,一般不經過處理,只用root用戶能使用tcpdump

  2.缺省只能同時使用4個tcpdump,如用完,則報此類錯。需要停掉多余的tcpdump

    文章來源:http://9399369.blog.51cto.com/9389369/1597675

上一篇:安卓防火墻 PS DroidWall

下一篇:TCPDump介紹