linux下3种检测远程端口是否打开的方法
方法一. 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 ""|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