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 语句

相关推荐
凡人叶枫5 小时前
Effective C++ 条款23:宁以 non-member、non-friend 替换 member 函数
linux·开发语言·c++·嵌入式开发
不会C语言的男孩5 小时前
Linux 系统编程 · 第 4 章:文件属性与元数据
linux·c语言·开发语言
小生不才yz6 小时前
Shell脚本精读 · S02-03 | 词拆分、通配符与未加引号的变量
linux
2601_961845426 小时前
法考真题及答案解析|历年真题|资料已整理
linux·windows·ubuntu·macos·centos·gnu
A_humble_scholar6 小时前
Linux(七)调度器:从硬件矛盾到进程切换的底层逻辑
linux·服务器·网络
AOwhisky6 小时前
Redis 学习笔记(第四期):高可用与集群(哨兵 + Cluster + 容器化)
linux·运维·数据库·redis·笔记·学习·缓存
零陵上将军_xdr6 小时前
Shell脚本入门:从Hello World到变量的灵活运用
linux
C语言小火车7 小时前
嵌入式Linux应用开发技术栈完全指南
linux·运维·服务器
m0_738120727 小时前
渗透测试基础——基于Docker的Rsync服务靶场搭建与原理讲解
运维·服务器·网络·安全·web安全·docker·容器
12点一刻8 小时前
Hermes Agent 与 Superpowers 框架的区别?
运维·服务器