今天和你聊聊PING命令。
一般來說,網工們通常會用它來直接ping ip地址,來測試網絡的連通情況。
類似這種,ping ip地址或網關,然后ping通后會顯示出以上數據。
再通過Ping返回的TTL值大小,粗略地判斷目標系統類型是Windows系列還是UNIX/Linux系列。
但你還了解別的嗎,除了這個,PING還能這么用?
ping-t、ping-a、ping-n、ping-l size、ping-r count,這些你都用上了嗎?
ping幾百到1000個ip地址,怎么批量?
今天就來討論下PING的其他用法,你用過幾個,又有幾個還沒用上。
ping-t的使用
不間斷地Ping指定計算機,直到管理員中斷。
可以按住鍵盤的Ctrl+C終止它繼續ping下去,就會停止了,會總結出運行的數據包有多少,通斷的有多少。
ping-a的使用
ping-a解析計算機名與NetBios名。
就是可以通過ping它的ip地址,可以解析出主機名。
當你遇到一個ip,卻不知道它是哪個設備時,這時你可以通過ping -a知道它的主機名。
ping-n的使用
在默認情況下,一般都只發送四個數據包。
通過這個命令可以自己定義發送的個數,對衡量網絡速度很有幫助。
比如你想測試發送10個數據包的返回的平均時間為多少,最快時間為多少,最慢時間為多少?
可以這樣獲知:
從上面操作,你就可以知道在給47.93.187.142發送10個數據包的過程當中,返回了10個,沒有丟失,這10個數據包當中返回速度最快為32ms,最慢為55ms,平均速度為37ms。
說明你的網絡良好。
如果對于一些不好的網絡,比如監控系統中非常卡頓,這樣測試,返回的結果可能會顯示出丟失出一部分。
丟失的比較多的話,那么就說明網絡不好。
通過這個,可以很直觀地判斷出網絡的情況。
ping-l size的使用
ping-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的數據包。
如果你只有一臺計算機也許沒有什么效果,但有很多計算機,就可以使對方完全癱瘓,網絡嚴重堵塞,由此可見威力非同小可。
ping-r count
這個命令在“記錄路由”字段中記錄傳出和返回數據包的路由,探測經過的路由個數,但最多只能跟蹤到9個路由。
ping -n 1 -r 9 202.102.224.25 (發送一個數據包,最多記錄9個路由)。
將經過 9個路由都顯示出來了,可以看上圖。
也就是說可以跟蹤ip地址所經過的9個路由,在檢查故障時可以快速定位。
如何同時批量ping多個IP地址
01ping一個網段
對于一個網段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檢測完為止。
02ping網段升級
上面的命令雖然能批量ping 地址,但是代碼在命令行窗口顯示數量多的時候看起來也很麻煩,那么再升級一下,用下面的代碼。
for /L %D in (1,1,255) do ping -n 10.168.1.%D >>a.txt
說明,ip地址是變的,你填你需要測的ip網段就行,a.txt也是變的,可以自己設置名稱。
這樣就會把結果導入到a.txt文件中,全部IP檢查完成后打開a.txt搜索“TTL=”包含它的就是通的地址,沒有包含“TTL=”的地址就是不通的。
如下圖:
打開后,就直接搜索沒TTL的就可以了。
03ping網段命令再升級
很多人要說了這樣還要搜索,也不是太方便,需要這樣查來查去,那么你再看下,是否有更簡便的方法呢?
第一監控之前就發過。
答案肯定是有的,你看代碼。
for /l %D in (1,1,255) do (ping 192.168.1.%D -n 1 && echo 192.168.1.%D>>ok.txt || echo 192.168.1.%D >>no.txt)
這段代碼會將ping通的IP和不通的IP分別放到兩個文件里面,這樣是不是很方便啦,如下圖:
這段代碼非常實用,在大網絡中可以用到,就是大家在輸入的時候需要細心,不過也沒有關系,可以直接把這個文章收藏,日后要用,直接復制里面代碼,然后改下里面ip地址就行了。
04ping網段命令終極方法
上面提到的三種代碼提到的都是針對同一個網段內ip地址批量檢測,那么肯定在實際項目中,也可能存不同網段的ip地址需要同時檢測,那么怎么辦呢?
也有方法,可以把沒有規劃的ip地址同時批量檢測,你來看下代碼:
for /f %D in (ip.txt) do (ping %D -n 1 && echo %i>>ok.txt || echo %D >>no.txt)
看見沒,多了一個ip.txt文件,這個文件是要你自己準備的。
把你ping的地址寫到這個文件里面,同時可以ping 1000個ip地址以上,代碼會自己讀取這個文件里面的ip地址,并且把結果放到兩個文件里面去。
這里就不給大家截圖了很容易理解。
以及補充下:
上面代碼生成的文件在你命令行默認目錄下。也就是說如果你的命令行狀態是:
'c:windowssystem32>'那么生成的文件就在系統的system32目錄下面。如果是'c:'那么文件就在C盤根目錄下。
這個可以根據你的實際情況進行調整。
-
數據
+關注
關注
8文章
7048瀏覽量
89070 -
網絡
+關注
關注
14文章
7570瀏覽量
88819 -
ping命令
+關注
關注
0文章
4瀏覽量
2391
原文標題:想不到吧,原來ping還能這么用
文章出處:【微信號:網絡工程師筆記,微信公眾號:網絡工程師筆記】歡迎添加關注!文章轉載請注明出處。
發布評論請先 登錄
相關推薦
評論