隨著技術(shù)的不斷的升級和改造。Linux操作系統(tǒng)逐漸被人所熟知并應(yīng)用。當(dāng)在Linux操作系統(tǒng)的服務(wù)器運(yùn)行時(shí),它還將表征各種參數(shù)信息。一般而言,運(yùn)維人員和系統(tǒng)管理員對這些數(shù)據(jù)非常敏感,因此這些參數(shù)對開發(fā)人員也非常重要,尤其是在您的程序無法正常工作時(shí),這些提示通常有助于快速定位和跟蹤問題。那么遠(yuǎn)程Linux 系統(tǒng)時(shí),如何檢測多個(gè)服務(wù)器上的端口是否打開?
如果要檢查五個(gè)服務(wù)器有沒有問題,可以使用以下任何一個(gè)命令,如 nc(netcets/tca/' target='_blank'>tcat)、nmap 和 telnet。但是如果想檢查50 多臺(tái)服務(wù)器,那么你的解決方案是什么?
要檢查所有服務(wù)器并不容易,如果你一個(gè)一個(gè)這樣做,完全沒有必要,因?yàn)檫@樣你將會(huì)浪費(fèi)大量的時(shí)間。為了解決這種情況,我使用 nc 命令編寫了一個(gè)shell 小腳本,它將允許我們掃描任意數(shù)量服務(wù)器給定的端口。
如果你要查找單個(gè)服務(wù)器掃描,你有多個(gè)選擇,你只需閱讀 檢查遠(yuǎn)程 Linux 系統(tǒng)上的端口是否打開? 了解更多信息。
本教程中提供了兩個(gè)腳本,這兩個(gè)腳本都很有用。這兩個(gè)腳本都用于不同的目的,你可以通過閱讀標(biāo)題輕松理解其用途。
什么是nc(netcat)命令?
nc 即netcat。它是一個(gè)簡單實(shí)用的Unix 程序,它使用TCP 或UDP 協(xié)議進(jìn)行跨網(wǎng)絡(luò)連接進(jìn)行數(shù)據(jù)讀取和寫入。
它被設(shè)計(jì)成一個(gè)可靠的 “后端” 工具,我們可以直接使用或由其他程序和腳本輕松驅(qū)動(dòng)它。
同時(shí),它也是一個(gè)功能豐富的網(wǎng)絡(luò)調(diào)試和探索工具,因?yàn)樗梢詣?chuàng)建你需要的幾乎任何類型的連接,并具有幾個(gè)有趣的內(nèi)置功能。
netcat 有三個(gè)主要的模式。分別是連接模式,監(jiān)聽模式和隧道模式。
nc(netcat)的通用語法:
$ nc [-options] [HostNameorIP] [PortNumber]
遠(yuǎn)程Linux 系統(tǒng)時(shí),如何檢測多個(gè)服務(wù)器上的端口是否打開?
如果要檢查多個(gè)遠(yuǎn)程Linux 服務(wù)器上給定端口是否打開,請使用以下shell 腳本。
在我的例子中,我們將檢查端口22 是否在以下遠(yuǎn)程服務(wù)器中打開,確保你已經(jīng)更新文件中的服務(wù)器列表而不是使用我的服務(wù)器列表。
你必須確保已經(jīng)更新服務(wù)器列表 :server-list.txt 。每個(gè)服務(wù)器(IP)應(yīng)該在單獨(dú)的行中。
#catserver-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
使用以下腳本可以達(dá)到此目的。
#viport_scan.sh
#!/bin/sh
forserver in`more server-list.txt`
do
#echo$i
nc -zvw3 $server 22
done
設(shè)置 port_scan.sh 文件的可執(zhí)行權(quán)限。
$ chmod+x port_scan.sh
最后運(yùn)行腳本來達(dá)到此目的。
#sh port_scan.sh
Connectionto 192.168.1.222port [tcp/ssh] succeeded!
Connectionto 192.168.1.322port [tcp/ssh] succeeded!
Connectionto 192.168.1.422port [tcp/ssh] succeeded!
Connectionto 192.168.1.522port [tcp/ssh] succeeded!
Connectionto 192.168.1.622port [tcp/ssh] succeeded!
Connectionto 192.168.1.722port [tcp/ssh] succeeded!
如何檢查多個(gè)遠(yuǎn)程Linux 服務(wù)器上是否打開多個(gè)端口?
如果要檢查多個(gè)服務(wù)器中的多個(gè)端口,請使用下面的腳本。
在我的例子中,我們將檢查給定服務(wù)器的22 和80 端口是否打開。確保你必須替換所需的端口和服務(wù)器名稱而不使用是我的。
你必須確保已經(jīng)將要檢查的端口寫入 port-list.txt 文件中。每個(gè)端口應(yīng)該在一個(gè)單獨(dú)的行中。
#catport-list.txt
22
80
你必須確保已經(jīng)將要檢查的服務(wù)器(IP 地址)寫入 server-list.txt 到文件中。每個(gè)服務(wù)器(IP) 應(yīng)該在單獨(dú)的行中。
#catserver-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
使用以下腳本來達(dá)成此目的。
#vimultiple_port_scan.sh
#!/bin/sh
forserver in`more server-list.txt`
do
forport in`more port-list.txt`
do
#echo$server
nc -zvw3 $server $port
echo""
done
done
設(shè)置 multiple_port_scan.sh 文件的可執(zhí)行權(quán)限。
$ chmod+x multiple_port_scan.sh
最后運(yùn)行腳本來實(shí)現(xiàn)這一目的。
#sh multiple_port_scan.sh
Connectionto 192.168.1.222port [tcp/ssh] succeeded!
Connectionto 192.168.1.280port [tcp/http] succeeded!
Connectionto 192.168.1.322port [tcp/ssh] succeeded!
Connectionto 192.168.1.380port [tcp/http] succeeded!
Connectionto 192.168.1.422port [tcp/ssh] succeeded!
Connectionto 192.168.1.480port [tcp/http] succeeded!
Connectionto 192.168.1.522port [tcp/ssh] succeeded!
Connectionto 192.168.1.580port [tcp/http] succeeded!
Connectionto 192.168.1.622port [tcp/ssh] succeeded!
Connectionto 192.168.1.680port [tcp/http] succeeded!
Connectionto 192.168.1.722port [tcp/ssh] succeeded!
Connectionto 192.168.1.780port [tcp/http] succeeded!
綜上所述,遠(yuǎn)程Linux 系統(tǒng)時(shí),如何檢測多個(gè)服務(wù)器上的端口是否打開相信大家已經(jīng)知曉了,想了解更多關(guān)于Linux的信息,請繼續(xù)關(guān)注中培偉業(yè)。