在实际运维中,客户会常常哀求帮忙测试某一地址和端口是否是联通状态,但有时客户反馈实际利用中有时是能访问通,有时访问不对,于是,按客户的哀求,测试下来,创造:
telnet结果是通的,但客户反馈做事访问此地址时,很大概率还会涌现超时的情形。根本部门建议循环telnet看下,是不是不稳定。
当时是手动多次重复实行telnet命令,创造确实有部分telnet不通的情形。

telnet 192.168.1.9 443
批量telnet脚本
以下为通过脚本形式,实现批量telnet的方法:
192.168.1.9节点的tmp目录下新建过cheng文件夹。
循环telnet,shell脚本如下:
# ====================脚本开始============PORT=XXXXcount=0for i in $(cat ip_list.txt)do((count++))echo "count=$count"# 关键代码,1s自动结束telnet(sleep 1;) | telnet $i $PORT >>telnet_result.txtdone# 根据结果判断出正常可以ping通的ipcat telnet_result.txt | grep -B 1 \] | grep [0-9] | awk '' | cut -d '.' -f 1,2,3,4 >telnet_alive.txt# 差集,得到ping不同的ipcat ip_list.txt telnet_alive.txt | sort | uniq -u >telnet_die.txt# ====================脚本结束==================
实行步骤:
1、在Linux环境中运行,首先建文件夹如cheng(mkdir cheng),然后vim创建telnet.sh(vi telnet.sh)文件将上述代码复制进去,修正XXXX为实际端口号例如linux的远程端口22,保存退出。
2、在cheng文件夹中创建ip_list.txt(vim ip_list.txt)的文件,并输入要检讨的做事器IP地址,每行一个地址。
3、实行telnet.sh(sh telnet.sh 或 bash telnet.sh)文件,等待结果。
4、cheng文件夹目录文件先容
shell文件夹中会新涌现3个新的文件,如下:
telnet_alive.txt#端口通的地址凑集
telnet_die.txt#端口不通的地址凑集
telnet_result.txt#所有地址检讨结果
5、查看脚本实行结果,一样平常我们查看telnet_alive.txt文件即可。
脚本实行时,可能会报错:syntax error near unexpected token `
报销是由于我在windows7里写的shell脚本,传到CentOS系统里运行就可以会提示syntax error near unexpected token `缺点,是由于两个别系的换行符不一样导致的。
须要利用notepad++转换下格式,转换方法
1、把脚本利用notepad++打开,点击“视图”->“显示符号”->显示所有字符,将所有字符显示出来,调度完造诣会创造文档中涌现CR LF,表示换行回车符
2、接下来,点击“编辑”->“档案格式转换”->“转换为UNIX格式”,目的是将windows的格式转为linux或unix格式
3、转换完成,换行回车符自动变成【LF】,这里再上传到做事上就可以了。
以上办法是固定端口。要telnet多个不同端口的话脚本须要修正一下,去掉上面脚本的Port部分,并改用while read line循环:
Shell脚本for和while的差异,for是按行读取,但如果行内笔墨有空格或tab等,则分开读取,即一次读取一个字符串。
如www.baidu.com 80,就会变成两行了,www.baidu.com一行, 80一行。telnet就会实行不下去。
While是整行读取,不管行内有多少段笔墨。
其余ip_list.txt须要改为ip + 端口
脚本如下:
count=0cat ip_list.txt|while read linedo((count++))echo "count=$count"echo "$line"# 关键代码,1s自动结束telnet(sleep 1;) | telnet $line >>telnet_result.txtdone# 根据结果判断出正常可以ping通的ipcat telnet_result.txt | grep -B 1 \] | grep [0-9] | awk '' | cut -d '.' -f 1,2,3,4 >telnet_alive.txt# 差集,得到ping不同的ipcat ip_list.txt telnet_alive.txt | sort | uniq -u >telnet_die.txt
但这个多端口的办法,天生的telnet_alive.txt始终为空,telnet_die.txt也有不对的情形涌现(比如www.baidu.com 80实际是通的,却涌如今telnet_die.txt里)。可能是ip_list.txt加了端口,相应的判断也须要改下。也可能是sleep 1韶光不足长,前一个地址超时等待的时候,下一个地址又开始telnet,造成统计结果不准确。
实在从sh telnet.sh的实行结果上就能看出通不通了,下图报timed out的便是不通的。
利用nc命令判断端口情形
在Linux中有如下一条语句,也可以考验端口是否通
nc -zv origin-creation.com 443
没有nc的做事器,须要 yum install -y nc 安装一下。
这个命令不像telnet,须要手动退出才能实行下一个命令。可以利用此方法,手动多次重复实行,判断是否有不通的情形。
在Docker容器里也可以安装nc命令,安装命令:
apk add nc
安装之后可以在docker容器里,测试端口情形。
利用CURL命令判断端口情形除telnet、nc之后,还可以通过curl来判断端口是否通,语句如下:
curl origin-creation.com:443 #把稳地址和端口间的冒号“:”,一定不要落下
利用curl命令,相称于利用浏览器访问或利用postman等接口调用工具返回,返回只要不是timeout,基本均不通的状态,返回内容取决于端口返回内容
批量curl,循环curl脚本
在做事器任意位置创建文件,建议利用root用户,避免权限问题
vim forcurl
#!/bin/bash for i in {1..1000} do echo '第一个IP: 192.168.1.9 8000端口,第' $i '次访问.........,' time curl '192.168.1.9:8000' echo '第二个IP: 10.11.12.100 8000端口,第' $i '次访问.........' time curl '10.11.12.100:32767 ' echo '如果有多个ip,可以连续按照上边,连续写下去,脚本里不限定。。。。。' echo '======用于区分次数=============' done
以上脚本是循环1000次,测试两个ip和端口的畅通性,每次均记录次数和访问结果,可自动调度次数,调度方法,将 for i in {1..1000}中的1000,换成对应次数即可。
脚本编写完成后,按esc键,再按“冒号wq”,保存退出。
利用以下命令实行并查当作果:
sh forcurl
以上即为Linux系统常见的检测端口畅通情形~