在实际运维中,顾客会常常要求协助测试某一地址和端口是否是移动状态,但有时顾客反馈实际使用中有时是能访问通,有时访问不对,于是,按顾客的要求,测试出来,发觉:
telnet结果是通的,但顾客反馈服务访问此地址时,很大机率就会出现超时的情况。基础部门建议循环telnet看下,是不是不稳定。
当时是自动多次重复执行telnet命令,发觉确实有部份telnet不通的情况。
telnet测试方式
telnet 192.168.1.9 443
以下为通过脚本方式,实现批量telnet的方式:
192.168.1.9节点的tmp目录下新建过fú文件夹。
循环telnet,shell脚本如下:
# ====================脚本开始============
PORT=XXXX
count=0
for i in $(cat ip_list.txt)
do
((count++))
echo "count=$count"
# 关键代码,1s自动结束telnet
(sleep 1;) | telnet $i $PORT >>telnet_result.txt
done
# 根据结果判断出正常可以ping通的ip
cat telnet_result.txt | grep -B 1 ] | grep [0-9] | awk '' | cut -d '.' -f 1,2,3,4 >telnet_alive.txt
# 差集,得到ping不同的ip
cat ip_list.txt telnet_alive.txt | sort | uniq -u >telnet_die.txt
# ====================脚本结束==================
执行步骤:
1、在Linux环境中运行,首先建文件夹如fú(mkdirfú),之后vim创建telnet.sh(vitelnet.sh)文件将上述代码复制进去,更改XXXX为实际端标语诸如linux的远程端口22,保存退出。
2、在fú文件夹中创建ip_list.txt(vimip_list.txt)的文件,并输入要检测的服务器IP地址,每行一个地址。
3、执行telnet.sh(shtelnet.sh或bashtelnet.sh)文件,等待结果。
4、cheng文件夹目录文件介绍
shell文件夹中会新出现3个新的文件,如下:
telnet_alive.txt#端口通的地址集合
telnet_die.txt#端口不通的地址集合
telnet_result.txt#所有地址检测结果
5、查看脚本执行结果,通常我们查看telnet_alive.txt文件即可。
脚本执行时,可能会报错:syntaxerrornearunexpectedtoken`
报销是由于我在windows7里写的shell脚本,传到CentOS系统里运行就可以会提示syntaxerrornearunexpectedtoken`错误,是由于两个系统的换行符不一样引起的。
须要使用notepad++转换下格式,转换方式
1、把脚本使用notepad++打开,点击“视图”->“显示符号”->显示所有字符,将所有字符显示下来,调整完成都会发觉文档中出现CRLF,表示换行回车符
2、接出来,点击“编辑”->“档案格式转换”->“转换为UNIX格式”,目的是将windows的格式转为linux或unix格式
3、转换完成linux cr lf,换行回车符手动弄成【LF】,这儿再上传到服务上就可以了。
以上方法是固定端口。要telnet多个不同端口的话脚本须要更改一下,除去前面脚本的Port部份,并改用whilereadline循环:
Shell脚本for和while的区别,for是按行读取,但倘若行内文字有空格或tab等,则分开读取,即一次读取一个字符串。
如80,都会弄成两行了,一行,80一行。telnet才会执行不下去。
While是整行读取,不管行内有多少段文字。
另外ip_list.txt须要改为ip+端口
脚本如下:
count=0
cat ip_list.txt|while read line
do
((count++))
echo "count=$count"
echo "$line"
# 关键代码,1s自动结束telnet
(sleep 1;) | telnet $line >>telnet_result.txt
done
# 根据结果判断出正常可以ping通的ip
cat telnet_result.txt | grep -B 1 ] | grep [0-9] | awk '' | cut -d '.' -f 1,2,3,4 >telnet_alive.txt
# 差集,得到ping不同的ip
cat ip_list.txt telnet_alive.txt | sort | uniq -u >telnet_die.txt
但这个多端口的方法,生成的telnet_alive.txt一直为空,telnet_die.txt也有不对的情况出现(例如80实际是通的,却出现在telnet_die.txt里)。可能是ip_list.txt加了端口,相应的判定也须要改下。也可能是sleep1时间不够长,前一个地址超时等待的时侯,下一个地址又开始telnet,导致统计结果不确切。
虽然从shtelnet.sh的执行结果上才能看出通不通了,右图报timedout的就是不通的。
使用nc命令判定端口情况
在Linux中有如下一条句子,也可以检验端口是否通
nc -zv origin-creation.com 443
没有nc的服务器,须要yuminstall-ync安装一下。
这个命令不像telnet红旗linux5.0,须要自动退出能够执行下一个命令。可以使用此方式,自动多次重复执行,判定是否有不通的情况。
在Docker容器里也可以安装nc命令,安装命令:
apk add nc
安装以后可以在docker容器里,测试端口情况。
使用CURL命令判定端口情况
除telnet、nc以后,还可以通过curl来判定端口是否通,句子如下:
curl origin-creation.com:443 #注意地址和端口间的冒号“:”,一定不要落下
使用curl命令,相当于使用浏览器访问或使用postman等插口调用工具返回,返回只要不是timeout,基本均不通的状态,返回内容取决于端口返回内容
批量curllinux多线程编程,循环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次linux cr lf,测试两个ip和端口的畅通性,每次均记录次数和访问结果,可手动调整次数,调整方式,将foriin{1..1000}中的1000,换成对应次数即可。
脚本编撰完成后,按esc键,再按“冒号wq”,保存退出。
使用以下命令执行并查看结果:
sh forcurl
以上即为Linux系统常见的测量端口畅通情况~