Linux shell 批量验证端口连通性

脚本

bash 复制代码
#!/bin/bash
#
#database check
#set -o nounset
LOCALIP=`ifconfig | grep inet | head -1 | awk '{print $2}' | sed 's/addr\://'`
IPLIST='192.168.1.99 192.168.1.98 192.168.1.97'
PORTLIST='81 82 83 84 85 86'
check_nc(){
for CHECK_IP in $IPLIST
do
    for CHECK_PORT in $PORTLIST
        do
            nc -nz -w 1 $CHECK_IP $CHECK_PORT
            if [ $? -eq 0 ];then
                echo "$LOCALIP result $CHECK_IP $CHECK_PORT 连通"
            else
                echo "$LOCALIP result $CHECK_IP $CHECK_PORT 不连通"
            fi
        done
done
}
check_nc_7(){
for CHECK_IP in $IPLIST
do
    for CHECK_PORT in $PORTLIST
        do
            nc -n -w 1 $CHECK_IP $CHECK_PORT < /dev/null
            if [ $? -eq 0 ];then
                echo "$LOCALIP result $CHECK_IP $CHECK_PORT 连通"
            else
                echo "$LOCALIP result $CHECK_IP $CHECK_PORT 不连通"
            fi
        done
done
}
check_telnet(){
for CHECK_IP in $IPLIST
do
    for CHECK_PORT in $PORTLIST
        do
            echo  -e  "\n"| telnet $CHECK_IP $CHECK_PORT | grep Connected            if [ $? -eq 0 ];then
                echo "$LOCALIP result $CHECK_IP $CHECK_PORT 不连通"
            else
                echo "$LOCALIP result $CHECK_IP $CHECK_PORT 连通"
            fi
        done
done
}
echo "--------------------------------------"
echo "execution time : `date`"
echo "--------------------------------------"
echo "Home ip : $LOCALIP"
echo "--------------------------------------"
which nc > /dev/null
if [ $? -eq 0 ];then
    echo "------------------nc------------------"
    echo "--------------------------------------"
    cat /etc/redhat-release |grep 'release 7' > /dev/null
    if [ $? -eq 0 ];then
        check_nc_7
    else
        check_nc
    fi
else
    which telnet > /dev/null
    if [ $? -eq 0 ];then
        echo "-----------------telnet----------------"
        check_telnet
    fi
fi

此脚本考虑了nc及telnet命令,及nc在redhat 7中应用的不同。可以直接复制使用,只要修改一下IP和端口。

telnet 命令语法

telnet [主机名或IP地址] [端口号]

nc 命令语法

bash 复制代码
nc [选项] [目标IP] [端口号]

常用选项包括‌:

  • -l:监听模式,在目标IP上开启一个监听服务器。
  • -p:指定要使用的本地端口。
  • -e:将输入和输出重定向到程序。
  • -n:不解析主机名和端口号。
  • -v:显示详细的调试信息。
  • -z:使用零I/O模式,只扫描监听端口是否开放,不发送任何数据。
  • -u:使用UDP协议进行通信。
  • -w:设置超时时间。

常见用法包括‌:

  1. 监听一个端口‌:

    bash 复制代码
    nc -l 监听端口

    功能:将目标IP上指定端口设为监听状态,等待连接。

  2. 端口扫描‌:

    bash 复制代码
    nc -zv 目标IP 起始端口-结束端口

    功能:扫描目标IP上某个范围的端口,查看哪些端口处于开放状态。

  3. 发送和接收数据‌:

    bash 复制代码
    nc 目标IP 目标端口

    功能:与目标IP上的指定端口进行TCP连接,并通过标准输入输出发送和接收数据。

  4. 将文件发送给远程主机‌:

    bash 复制代码
    nc 目标IP 目标端口 < 文件名

    功能:将本地文件发送给目标IP上的指定端口。

评价

很好用,如果是国产机可能需要注释掉两行 which 语句

相关推荐
开开心心_Every13 分钟前
限时免费加密、隐藏、锁定文件文件夹好工具
运维·服务器·人工智能·edge·pdf·逻辑回归·深度优先
RisunJan38 分钟前
Linux命令-modprobe(自动处理可载入模块)
linux·运维
野犬寒鸦38 分钟前
Redis复习记录day1
服务器·开发语言·数据库·redis·缓存
龙俊俊40 分钟前
服务器模型部署与加载
服务器·人工智能·深度学习
何朴尧1 小时前
OpenClaw Linux 完整安装指南
linux
木木em哈哈1 小时前
记一次在线编辑器的探索
linux·服务器·网络
我要成为嵌入式大佬1 小时前
正点原子MP157--问题详解--二(NFS挂载根文件系统双网卡设置)
linux·服务器·网络
一个有温度的技术博主2 小时前
网安实验系列七:域名收集
linux·运维·服务器
我爱学习好爱好爱2 小时前
Ansible 环境搭建
linux·运维·ansible
野犬寒鸦2 小时前
Redis热点key问题解析与实战解决方案(附大厂实际方案讲解)
服务器·数据库·redis·后端·缓存·bootstrap