ping 和 traceroute 命令


ping 和 traceroute 命令

 

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程序:向目的發送具有不同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,用戶可另行設置。

 

參數說明:

-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、記錄按序列號從1開始,每個紀錄就是一跳 ,每跳表示一個網關,我們看到每行有三個時間,單位是 ms,其實就是-q的默認參數。探測數據包向每個網關發送三個數據包后,網關響應后返回的時間;如果您用 traceroute -q 4 www.58.com ,表示向每個網關發送4個數據包。
2、有時我們traceroute 一台主機時,會看到有一些行是以星號表示的。出現這樣的情況,可能是防火牆封掉了ICMP的返回信息,所以我們得不到什么相關的數據包返回數據。
3、有時我們在某一網關處延時比較長,有可能是某台網關比較阻塞,也可能是物理設備本身的原因。當然如果某台DNS出現問題時,不能解析主機名、域名時,也會 有延時長的現象;您可以加-n 參數來避免DNS解析,以IP格式輸出數據。
4、如果在局域網中的不同網段之間,我們可以通過traceroute 來排查問題所在,是主機的問題還是網關的問題。如果我們通過遠程來訪問某台服務器遇到問題時,我們用到traceroute 追蹤數據包所經過的網關,提交IDC服務商,也有助於解決問題;

 

 

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


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM