佩服!ping 命令還能這麼玩?

有朋友反映,能不能講下 ping 命令的使用,其實對於命令的使用咱們以前提到過一些,但對 ping 命令沒有過多講解,通常咱們用的都是它的基本功能,今天咱們來詳細看下 ping 命令詳細使用。ios

做者:Pheenet菲尼特segmentfault

https://www.toutiao.com/a6783...服務器

1、ping 基本使用詳解

在網絡中 ping 是一個十分強大的 TCP/IP 工具。它的做用主要爲:網絡

一、用來檢測網絡的連通狀況和分析網絡速度工具

二、根據域名獲得服務器 IP測試

三、根據 ping 返回的 TTL 值來判斷對方所使用的操做系統及數據包通過路由器數量。spa

咱們一般會用它來直接 ping ip 地址,來測試網絡的連通狀況。操作系統

類如這種,直接 ping ip 地址或網關,ping 通會顯示出以上數據,有朋友可能會問,bytes=32;time<1ms;TTL=128 這些是什麼意思。命令行

bytes 值:數據包大小,也就是字節。blog

time 值:響應時間,這個時間越小,說明你鏈接這個地址速度越快。

TTL 值:Time To Live, 表示 DNS 記錄在 DNS 服務器上存在的時間,它是 IP 協議包的一個值,告訴路由器該數據包什麼時候須要被丟棄。能夠經過 Ping 返回的 TTL 值大小,粗略地判斷目標系統類型是 Windows 系列仍是 UNIX/Linux 系列。

默認狀況下,Linux 系統的 TTL 值爲 64 或 255,WindowsNT/2000/XP 系統的 TTL 值爲 128,Windows98 系統的 TTL 值爲 32,UNIX 主機的 TTL 值爲 255。

所以通常 TTL 值:

100~130ms 之間,Windows 系統 ;

240~255ms 之間,UNIX/Linux 系統。

固然,咱們今天主要了解並非這些,而是 ping 的其它參考。

ping 命令除了直接 ping 網絡的 ip 地址,驗證網絡暢通和速度以外,它還有這些用法。

2、ping -t 的使用

不間斷地 Ping 指定計算機,直到管理員中斷。

這就說明電腦鏈接路由器是通的,網絡效果很好。下面按按住鍵盤的 Ctrl+c 終止它繼續 ping 下去,就會中止了,會總結出運行的數據包有多少,通斷的有多少了。

3、ping -a 的使用

ping-a 解析計算機名與 NetBios 名。就是能夠經過 ping 它的 ip 地址,能夠解析出主機名。

4、ping -n 的使用

在默認狀況下,通常都只發送四個數據包,經過這個命令能夠本身定義發送的個數,對衡量網絡速度頗有幫助,好比我想測試發送 10 個數據包的返回的平均時間爲多少,最快時間爲多少,最慢時間爲多少就能夠經過如下獲知:

從以上我就能夠知道在給 47.93.187.142 發送 10 個數據包的過程中,返回了 10 個,沒有丟失,這 10 個數據包當中返回速度最快爲 32ms,最慢爲 55ms,平均速度爲 37ms。說明個人網絡良好。

若是對於一些很差的網絡,好比監控系統中很是卡頓,這樣測試,返回的結果可能會顯示出丟失出一部分,若是丟失的比較多的話,那麼就說明網絡很差,能夠很直觀的判斷出網絡的狀況。

5、ping -l size 的使用

-l size:發送 size 指定大小的到目標主機的數據包。

在默認的狀況下 Windows 的 ping 發送的數據包大小爲 32byt,最大能發送 65500byt。當一次發送的數據包大於或等於 65500byt 時,將可能致使接收方計算機宕機。因此微軟限制了這一數值;這個參數配合其它參數之後危害很是強大,好比攻擊者能夠結合 - t 參數實施 DOS 攻擊。(因此它具備危險性,不要輕易向別人計算機使用)。

例如:ping -l 65500 -t 211.84.7.46

會連續對 IP 地址執行 ping 命令,直到被用戶以 Ctrl+C 中斷.

這樣它就會不停的向 211.84.7.46 計算機發送大小爲 65500byt 的數據包,若是你只有一臺計算機也許沒有什麼效果,但若是有不少計算機那麼就可使對方徹底癱瘓,網絡嚴重堵塞,因而可知威力非同小可。

6、ping -r count 的使用

在 「記錄路由」 字段中記錄傳出和返回數據包的路由,探測通過的

路由個數,但最多隻能跟蹤到 9 個路由。

ping -n 1 -r 9 202.102.224.25 (發送一個數據包,最多記錄 9 個路由)

將通過 9 個路由都顯示出來了,能夠看上圖。

ping 命令用的較多的就這 6 類的,你們有可能在項目中會用到的。

7、批量 Ping 網段

對於一個網段 ip 地址衆多,若是單個檢測實在麻煩,那麼咱們能夠直接批量 ping 網段檢測,那個 ip 地址出了問題,一目瞭然。

先看代碼,直接在命令行窗口輸入:

for /L %D in (1,1,255) do ping 10.168.1.%D

IP 地址段修改爲你要檢查的 IP 地址段。

當輸入批量命令後,那麼它就自動把網段內全部的 ip 地址都 ping 完爲止。

那麼這段 「for /L %D in(1,1,255) do ping 10.168.1.%D」 代碼是什麼意思呢?

代碼中的這個 (1,1,255) 就是網段起與始,就是檢測網段 192.168.1.1 到 192.168.1.255 之間的全部的 ip 地址,每次逐增 1,直接到 1 到 255 這 255 個 ip 檢測完爲止。

若有錯誤或其它問題,歡迎小夥伴留言評論、指正。若有幫助,歡迎點贊+轉發分享。

歡迎你們關注民工哥的公衆號:民工哥技術之路
image.png

相關文章
相關標籤/搜索