百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

Linux 测试端口(批量测试端口)畅通性

nanshan 2024-10-22 13:01 41 浏览 0 评论

在实际运维中,客户会经常要求协助测试某一地址和端口是否是联通状态,但有时客户反馈实际使用中有时是能访问通,有时访问不对,于是,按客户的要求,测试下来,发现:

telnet结果是通的,但客户反馈服务访问此地址时,很大概率还会出现超时的情况。基础部门建议循环telnet看下,是不是不稳定。

当时是手动多次重复执行telnet命令,发现确实有部分telnet不通的情况。

telnet 测试方法

telnet  192.168.1.9 443

批量telnet脚本

以下为通过脚本形式,实现批量telnet的方法:

192.168.1.9节点的tmp目录下新建过cheng文件夹。

循环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环境中运行,首先建文件夹如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=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也有不对的情况出现(比如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系统常见的检测端口畅通情况~

相关推荐

详解 HTTPS、TLS、SSL、HTTP区别和关系

一、什么是HTTPS、TLS、SSLHTTPS,也称作HTTPoverTLS。TLS的前身是SSL,TLS1.0通常被标示为SSL3.1,TLS1.1为SSL3.2,TLS1.2为SSL...

锐安信SSL证书自动化运维系统:灵活管理SSL/TLS证书全生命周期

点击上方关注“锐成云分销”,云建站解决方案专家!域名、SSL证书、DNS、主机一站选齐在SSL/TLS证书的生命周期管理中,证书的各种操作方式是基础且核心的部分之一,更是保障用户数据传输加密的关键。这...

宝塔免费的 SSL/TLS 证书如何续签

申请之前,请确保域名已解析,如未解析会导致审核失败(包括根域名)宝塔SSL申请的是免费版TrustAsiaDVSSLCA-G5证书,仅支持单个域名申请有效期1年,不支持续签,到期后需要重新申...

HTTPS、HTTP、TLS/SSL工作及握手原理、PKI/CA密钥体系

一、HTTPS与HTTP介绍二、TLS/SSL工作原理三、TSL/SSL握手过程四、HTTPS性能优化五、PKI体系一、HTTPS与HTTP介绍1.Https(SecureHypetextTran...

什么是SSL证书卸载 SSL证书卸载有什么作用

SSL证书是数字证书的一种,安装部署的话可以对网站起到身份验证和数据加密的作用。网站部署SSL证书,相对就必然会有SSL证书卸载,那么SSL证书卸载是什么呢?SSL证书卸载有什么作用?随着SSL通信量...

让SSL/TLS协议流行起来:深度解读SSL/TLS实现1

一前言SSL/TLS协议是网络安全通信的重要基石,本系列将简单介绍SSL/TLS协议,主要关注SSL/TLS协议的安全性,特别是SSL规范的正确实现。本系列的文章大体分为3个部分:SSL/TLS协...

苹果、谷歌、微软等一致同意!SSL/TLS证书最长有效期锐减至47天

快科技4月14日消息,苹果此前向CA/B论坛(负责管理SSL/TLS证书的行业组织)提议,将所有证书有效期缩短至45天。日前CA/B论坛服务器证书工作组投票通过SC-081v3提案,最终决定将SSL/...

Android怎么设置端口转发,将访问本设备的端口转到另外一台设备

一、Android系统怎么设置端口转发,将访问本设备的端口转到另外一台设备?要设置端口转发,您需要先在Android设备上安装一个支持端口转发的应用程序。其中一个常用的应用是"Termux&#...

大神级产品:手机装 Linux 运行 Docker 如此简单

本内容来源于@什么值得买APP,观点仅代表作者本人|作者:灵昱Termux作为一个强大的Android终端模拟器,能够运行多种Linux环境。然而,直接在Termux上运行Docker并不可行,需要...

关于H3C交换机的SSH功能配置方法(华三交换机ssh配置)

对于交换机的初步学习,作为初学者的我,还望诸位不吝赐教。若存在不足之处,烦请大家多提宝贵意见。同样身为初学者的我们,亦可携手共进,相互分享技术经验。一、本地用户配置(核心步骤)1.创建用户并设置密码...

Linux常用操作ssh(linux中的ssh命令)

ssh#p是小写ssh-p22user@hostsftp#连接sftp-P22root@host#将文件上传到服务器上:put[本地文件的地址][服务器上文件存储的位置]#将...

小白心得,如何使用SSH连接飞牛系统(fnos)?

一、背景作为一个刚接触飞牛系统的小白,在研究飞牛os的时候,发现很多功能都需要连接ssh,但是如何使用SSH连接飞牛系统成为入门飞牛os的一道坎。下面以自己的学习经历详细记录下过程吧。二、系统设置1、...

如何在 Windows 11 或 10 上使用 Winget 安装 OpenSSH

SSH(SecureShell)是大多数开发人员和系统管理员用来通过Linux远程连接托管服务器或任何云服务的工具,因为SSH在Linux中是内置的。然而,对于Windows呢?是的...

linux文件之ssh配置文件的含义与作用

ssh远程登录命令是操作系统(包括linux和window系统)下常用的操作命令,可以帮助用户,远程登录服务器系统,查看,操作系统相关信息。linux系统对于ssh命令有专门保存其相关配置的目录和文件...

害怕Linux SSH不安全?这几个小妙招安排上!

ssh是访问远程服务器最常用的方法之一,同时,其也是Linux服务器受到攻击的最常见的原因之一。不过别误会...我们并不是说ssh有什么安全漏洞,相反,它在设计上是一个非常安全的协议。但是安...

取消回复欢迎 发表评论: