我們最近寫了一篇文章關於如何檢查遠端 Linux 伺服器是否開啟指定埠。它能幫助你檢查單個伺服器。
如果要檢查五個伺服器有沒有問題,可以使用以下任何一個命令,如 nc(netcat)、nmap 和 telnet。但是如果想檢查 50 多臺伺服器,那麼你的解決方案是什麼?
要檢查所有伺服器並不容易,如果你一個一個這樣做,完全沒有必要,因為這樣你將會浪費大量的時間。為瞭解決這種情況,我使用 nc 命令編寫了一個 shell 小指令碼,它將允許我們掃描任意數量伺服器給定的埠。
如果你要查詢單個伺服器掃描,你有多個選擇,你只需閱讀 檢查遠端 Linux 系統上的埠是否開啟?[1] 瞭解更多資訊。
本教程中提供了兩個指令碼,這兩個指令碼都很有用。這兩個指令碼都用於不同的目的,你可以透過閱讀標題輕鬆理解其用途。
在你閱讀這篇文章之前,我會問你幾個問題,如果你不知道答案你可以透過閱讀這篇文章來獲得答案。
如何檢查一個遠端 Linux 伺服器上指定的埠是否開啟?
如何檢查多個遠端 Linux 伺服器上指定的埠是否開啟?
如何檢查多個遠端 Linux 伺服器上是否開啟了多個指定的埠?
什麼是 nc(netcat)命令?
nc 即 netcat。它是一個簡單實用的 Unix 程式,它使用 TCP 或 UDP 協議進行跨網路連線進行資料讀取和寫入。
它被設計成一個可靠的 “後端” 工具,我們可以直接使用或由其他程式和指令碼輕鬆驅動它。
同時,它也是一個功能豐富的網路除錯和探索工具,因為它可以建立你需要的幾乎任何型別的連線,並具有幾個有趣的內建功能。
netcat 有三個主要的樣式。分別是連線樣式,監聽樣式和隧道樣式。
nc(netcat)的通用語法:
-
$ nc [-options] [HostName or IP] [PortNumber]
如何檢查多個遠端 Linux 伺服器上的埠是否開啟?
如果要檢查多個遠端 Linux 伺服器上給定埠是否開啟,請使用以下 shell 指令碼。
在我的例子中,我們將檢查埠 22 是否在以下遠端伺服器中開啟,確保你已經更新檔案中的伺服器串列而不是使用我的伺服器串列。
你必須確保已經更新伺服器串列 :server-list.txt
。每個伺服器(IP)應該在單獨的行中。
-
# cat server-list.txt
-
192.168.1.2
-
192.168.1.3
-
192.168.1.4
-
192.168.1.5
-
192.168.1.6
-
192.168.1.7
使用以下指令碼可以達到此目的。
-
# vi port_scan.sh
-
-
#!/bin/sh
-
for server in `more server-list.txt`
-
do
-
#echo $i
-
nc -zvw3 $server 22
-
done
設定 port_scan.sh
檔案的可執行許可權。
-
$ chmod +x port_scan.sh
最後執行指令碼來達到此目的。
-
# sh port_scan.sh
-
-
Connection to 192.168.1.2 22 port [tcp/ssh] succeeded!
-
Connection to 192.168.1.3 22 port [tcp/ssh] succeeded!
-
Connection to 192.168.1.4 22 port [tcp/ssh] succeeded!
-
Connection to 192.168.1.5 22 port [tcp/ssh] succeeded!
-
Connection to 192.168.1.6 22 port [tcp/ssh] succeeded!
-
Connection to 192.168.1.7 22 port [tcp/ssh] succeeded!
如何檢查多個遠端 Linux 伺服器上是否開啟多個埠?
如果要檢查多個伺服器中的多個埠,請使用下麵的指令碼。
在我的例子中,我們將檢查給定伺服器的 22 和 80 埠是否開啟。確保你必須替換所需的埠和伺服器名稱而不使用是我的。
你必須確保已經將要檢查的埠寫入 port-list.txt
檔案中。每個埠應該在一個單獨的行中。
-
# cat port-list.txt
-
22
-
80
你必須確保已經將要檢查的伺服器(IP 地址)寫入 server-list.txt
到檔案中。每個伺服器(IP) 應該在單獨的行中。
-
# cat server-list.txt
-
192.168.1.2
-
192.168.1.3
-
192.168.1.4
-
192.168.1.5
-
192.168.1.6
-
192.168.1.7
使用以下指令碼來達成此目的。
-
# vi multiple_port_scan.sh
-
-
#!/bin/sh
-
for server in `more server-list.txt`
-
do
-
for port in `more port-list.txt`
-
do
-
#echo $server
-
nc -zvw3 $server $port
-
echo ""
-
done
-
done
設定 multiple_port_scan.sh
檔案的可執行許可權。
-
$ chmod +x multiple_port_scan.sh
最後執行指令碼來實現這一目的。
-
# sh multiple_port_scan.sh
-
Connection to 192.168.1.2 22 port [tcp/ssh] succeeded!
-
Connection to 192.168.1.2 80 port [tcp/http] succeeded!
-
-
Connection to 192.168.1.3 22 port [tcp/ssh] succeeded!
-
Connection to 192.168.1.3 80 port [tcp/http] succeeded!
-
-
Connection to 192.168.1.4 22 port [tcp/ssh] succeeded!
-
Connection to 192.168.1.4 80 port [tcp/http] succeeded!
-
-
Connection to 192.168.1.5 22 port [tcp/ssh] succeeded!
-
Connection to 192.168.1.5 80 port [tcp/http] succeeded!
-
-
Connection to 192.168.1.6 22 port [tcp/ssh] succeeded!
-
Connection to 192.168.1.6 80 port [tcp/http] succeeded!
-
-
Connection to 192.168.1.7 22 port [tcp/ssh] succeeded!
-
Connection to 192.168.1.7 80 port [tcp/http] succeeded!
朋友會在“發現-看一看”看到你“在看”的內容