ping 和 traceroute 命令

ping命令

ping 程序 就是發送一個ICMP查詢報文給某服務器,以測試該服務器是否可達。
當返回ICMP回顯應答時,要打印出序列號、TTL,和往返時間;
[root@localhost src]# ping www.baidu.com
PING www.a.shifen.com (61.135.169.125) 56(84) bytes of data.
64 bytes from 61.135.169.125: icmp_seq=1 ttl=54 time=1.40 ms
64 bytes from 61.135.169.125: icmp_seq=2 ttl=54 time=1.43 ms

參數說明

-d 使用Socket的SO_DEBUG功能。
-f  極限檢測。大量且快速地送網絡封包給一臺機器,看它的迴應。
-n 只輸出數值。
-q 不顯示任何傳送封包的信息,只顯示最後的結果。
-r 忽略普通的Routing Table,直接將數據包送到遠端主機上。一般是查看本機的網絡接口是否有問題。
-R 記錄路由過程。
-v 詳細顯示指令的執行過程。
-c 數目:在發送指定數目的包後中止。
-i 秒數:設定間隔幾秒送一個網絡封包給一臺機器,預設值是一秒送一次。
-I 網絡界面:使用指定的網絡界面送出數據包。
-l 前置載入:設置在送出要求信息以前,先行發出的數據包。
-p 範本樣式:設置填滿數據包的範本樣式。
-s 字節數:指定發送的數據字節數,預設值是56,加上8字節的ICMP頭,一共是64ICMP數據字節。
-t 存活數值:設置存活數值TTL的大小。

測試丟包狀況

ping -c 1000 -f 10.75.49.29

traceroute命令

traceroute程序:向目的發送具備不一樣TTL的IP報文(封裝一個UDP格式的數據,並選擇一個不可能的值做爲UPD端口號),以肯定至目的地址的路由;
首先,traceroute發送一個TTL=1的IP報文,處理這份數據報的第一個路由器將TTL-1,而後丟棄該數據報,併發回一個ICMP超時報文,
這份包含ICMP信息的IP報文的信源地址就是該路由器的地址,這樣就獲得了該路徑中的第一個路由器的地址;
而後traceroute發送一個TTL=2的IP報文,能夠獲得第二個路由器的地址;繼續這個過程直到數據報送至目的主機。
 
當IP報文到的目的主機時,TTL=1,目的主機認爲數據報已經到達目的端,所以不會丟棄該報文;
但因爲目的主機上的任何一個應用程序都沒有使用指定的UPD端口號,所以會產生一個端口不可達的ICMP報文。
traceroute程序根據接收到的ICMP報文是超時、仍是端口不可達以判斷何時結束。
traceroute命令格式:
traceroute hostname

traceroute指令讓你追蹤網絡數據包的路由途徑,預設數據包大小是40Bytes,用戶可另行設置。php

參數說明:

-d 使用Socket層級的排錯功能
-f 設置第一個檢測數據包的存活數值TTL的大小
-F 設置勿離斷位
-g 設置來源路由網關,最多可設置8個
-i 使用指定的網絡界面送出數據包
-I 使用ICMP迴應取代UDP,有時能夠解決命令打印 「*」的問題
-m 設置檢測數據包的最大存活數值TTL的大小
-n 直接使用IP地址而非主機名稱,避免DNS解析
-p UDP傳輸協議的通訊端口

-q 設置探測包個數,默認爲3
-r 忽略普通的Routing Table,直接將數據包送到遠端主機上
-s 設置本地主機送出數據包的IP地址
-t 設置檢測數據包的TOS數值
-v 詳細顯示指令的執行過程
-w 設置等待遠端主機回報的時間
-x 開啓或關閉數據包的正確性檢驗

練習一下

[root@localhost ~]# traceroute www.baidu.com
traceroute to www.baidu.com (61.135.169.125), 30 hops max, 40 byte packets
 1  192.168.74.2 (192.168.74.2)  2.606 ms  2.771 ms  2.950 ms
 2  211.151.56.57 (211.151.56.57)  0.596 ms  0.598 ms  0.591 ms
 3  211.151.227.206 (211.151.227.206)  0.546 ms  0.544 ms  0.538 ms
 4  210.77.139.145 (210.77.139.145)  0.710 ms  0.748 ms  0.801 ms
 5  202.106.42.101 (202.106.42.101)  6.759 ms  6.945 ms  7.107 ms
 6  61.148.154.97 (61.148.154.97)  718.908 ms * bt-228-025.bta.net.cn (202.106.228.25)  5.177 ms
 7  124.65.58.213 (124.65.58.213)  4.343 ms  4.336 ms  4.367 ms
 8  202.106.35.190 (202.106.35.190)  1.795 ms 61.148.156.138 (61.148.156.138)  1.899 ms  1.951 ms
 9  * * *
30  * * *
[root@localhost ~]# 

說明

一、記錄按序列號從1開始,每一個紀錄就是一跳 ,每跳錶示一個網關,咱們看到每行有三個時間,單位是 ms,其實就是-q的默認參數。探測數據包向每一個網關發送三個數據包後,網關響應後返回的時間;若是您用 traceroute -q 4 www.58.com ,表示向每一個網關發送4個數據包。
二、有時咱們traceroute 一臺主機時,會看到有一些行是以星號表示的。出現這樣的狀況,多是防火牆封掉了ICMP的返回信息,因此咱們得不到什麼相關的數據包返回數據。
三、有時咱們在某一網關處延時比較長,有多是某臺網關比較阻塞,也多是物理設備自己的緣由。固然若是某臺DNS出現問題時,不能解析主機名、域名時,也會 有延時長的現象;您能夠加-n 參數來避免DNS解析,以IP格式輸出數據。
四、若是在局域網中的不一樣網段之間,咱們能夠經過traceroute 來排查問題所在,是主機的問題仍是網關的問題。若是咱們經過遠程來訪問某臺服務器遇到問題時,咱們用到traceroute 追蹤數據包所通過的網關,提交IDC服務商,也有助於解決問題;html

 

更網絡命令請參考:http://linux.vbird.org/linux_server/0140networkcommand.php linux

相關文章
相關標籤/搜索