linux下3種檢測遠端埠是否開啟的方法

pythontab發表於2019-06-21

方法一. telnet

常用telnet ip port方式測試遠端主機埠是否開啟。

方法二. nmap

nmap ip -p port 測試埠

nmap ip 顯示全部開啟的埠

根據顯示close/open確定埠是否開啟。

方法三. nc

nc -v host port

埠未開啟返回狀態為非0

一:telnet

此法常被用來檢測是個遠端埠是否通暢。

測試域名:

# telnet baidu.com 80
Trying 123.125.114.144...
Connected to baidu.com (123.125.114.144).         #==>出現Connected表示連通了,說
明百度的80埠開放的
Escape character is '^]'.             #==>按“ctrl+]”退出此地。
^]
telnet> quit
Connection closed.

測試IP地址:

# telnet 108.5.16.139 7506
Trying 108.5.16.139...
Connected to static-108-5-16-139.nycmny.fios.verizon.net (108.5.16.139).    #==>出
現Connected表示連通了,說明108.5.16.139的7506埠開放的
Escape character is '^]'.        #==>按“ctrl+]”退出此地
^]
telnet> quit
Connection closed.

如果寫指令碼透過telnet檢查埠可以用下面的方法:


# echo -e "\n"|telnet baidu.com 80|grep Connected
Connection closed by foreign host.
Connected to baidu.com (123.125.114.144).

二:透過nmap來檢查埠是否通暢

# nmap etiantian.org -p 80            
Starting Nmap 4.11 ( http://www.insecure.org/nmap/ ) at 2012-07-22 17:22 PDT
Interesting ports on 211.100.98.99:
PORT   STATE SERVICE
80/tcp open  http
Nmap finished: 1 IP address (1 host up) scanned in 0.417 seconds

如果寫指令碼透過nmap檢查埠可以用下面的方法:

PORT_COUNT=`nmap $ip_add  -p $port|grep open|wc -l`
[[ $PORT_COUNT -ge 1 ]] && echo "$ip_add $port is ok." || echo "$ip_add $port is unknown."

三:透過nc命令檢查

# nc -w 10  8.8.8.8 53 && echo ok ||echo no  
ok


相關文章