AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / unix / 问题 / 788022
Accepted
chris01
chris01
Asked: 2024-12-13 00:43:16 +0800 CST2024-12-13 00:43:16 +0800 CST 2024-12-13 00:43:16 +0800 CST

如何检查多个主机的简单连接?

  • 772

我需要一个工具来告诉我与主机的连接是否打开 - 没有数据要发送或接收。只要连接成功即可。

今天我使用 telnet。

$ telnet myhost myport
Trying 192.168.1.99...
Connected to myhost.
Escape character is '^]'.
^[^]
telnet> quit
Connection closed.

但我需要在那里手动输入。^]然后退出。

我需要检查多个主机,但这太多了。

有什么工具可以解决这一问题吗?

如果不行的话,我需要用 perl 写 15 行——这样也可以,但我更喜欢现有的工具。

bash
  • 4 4 个回答
  • 225 Views

4 个回答

  • Voted
  1. jesse_b
    2024-12-13T00:52:53+08:002024-12-13T00:52:53+08:00

    Bash 具有本机重定向功能,可以检查开放端口

    host=192.168.1.99
    if (echo > "/dev/tcp/${host}/22") >/dev/null 2>&1; then
      echo 'port is open'
    else
      echo 'port is closed'
    fi
    

    或者你可以使用 nc(1):

    host=192.168.1.99
    if timeout 3 nc -z "$host" 22 2>/dev/null; then
      echo 'port is open'
    else
      echo 'port is closed'
    fi
    

    您还可以通过将 telnet 传输到 grep 之类的程序来以编程方式使用 telnet:

    host=192.168.1.99
    if telnet "$host" 22 2>&1 | grep -q "Connected"; then
      echo 'port is open'
    else
      echo 'port is closed'
    fi
    
    • 4
  2. Best Answer
    Z0OM
    2024-12-13T01:08:42+08:002024-12-13T01:08:42+08:00

    使用此脚本,您可以检查主机是否在给定端口上响应:

    bash 的内置 /dev/tcp。

    您可以使用 IP 地址或域(主机名)。

    脚本 1 单端口

    #!/bin/bash
    
    HOST_NAME="127.1"
    HOST_PORT="80"
    
    if ( (exec 3<>/dev/tcp/${HOST_NAME}/${HOST_PORT}) 2> /dev/null); then
        echo -e "PORT: ${HOST_PORT} | ON"
        else
        echo -e "PORT: ${HOST_PORT} | OFF"
    fi
    
    

    脚本 2 端口范围

    #!/bin/bash
    
    HOST_NAME="127.1"
    
    for HOST_PORT in {1..1000}
    do
    
    if ( (exec 3<>/dev/tcp/${HOST_NAME}/${HOST_PORT}) 2> /dev/null); then
        echo -e "PORT: ${HOST_PORT} | ON"
        else
        echo -e "PORT: ${HOST_PORT} | OFF"
    fi
    done
    
    

    脚本 3 端口 1-65535

    #!/bin/bash
    
    HOST_NAME="127.1"
    declare -A PORT_ON
    
    for HOST_PORT in {1..65535}
    do
        if ( (exec 3<>/dev/tcp/${HOST_NAME}/${HOST_PORT}) 2> /dev/null); then
            PORT_ON[${HOST_PORT}]="ON"
        fi
    done
    
    for i in ${!PORT_ON[*]}
    do
        echo -e "$i : ${PORT_ON[$i]}"
    done
    
    
    • 4
  3. gowenfawr
    2024-12-13T12:00:53+08:002024-12-13T12:00:53+08:00

    现有的可以执行此操作的工具是nmap端口扫描器:

    $ nmap -sT -p 22 192.168.1.1-5
    Starting Nmap 7.95 ( https://nmap.org ) at 2024-12-12 22:52 Eastern Standard Time
    Nmap scan report for 192.168.1.1
    Host is up (0.0039s latency).
    
    PORT   STATE SERVICE
    22/tcp open  ssh
    MAC Address: 74:AC:B9:12:E1:93 (Ubiquiti)
    
    Nmap done: 5 IP addresses (1 host up) scanned in 1.47 seconds
    

    -sT表示 TCP 端口扫描 - 它将 SYN、ACK、SYN/ACK 然后 RST 连接。

    -p 22表示将测试端口 22。

    它可以扫描单个 IP、IP 范围(如上所示)、IP CIDR 块或这三者的任意组合。

    它还支持 XML 和 grep 输出,如下所示:

    $ nmap -sT -p 22 -oG - 192.168.1.1,3,5
    # Nmap 7.95 scan initiated Thu Dec 12 22:59:14 2024 as: nmap -sT -p 22 -oG - 192.168.1.1,3,5
    Host: 192.168.1.1 ()    Status: Up
    Host: 192.168.1.1 ()    Ports: 22/open/tcp//ssh///
    # Nmap done at Thu Dec 12 22:59:16 2024 -- 3 IP addresses (1 host up) scanned in 1.45 seconds
    
    • 4
  4. sarlacii
    2024-12-13T20:52:00+08:002024-12-13T20:52:00+08:00

    另一个现有的好工具是fping

    fping 是一个类似于 ping 的程序,它使用互联网控制消息协议回显请求来确定目标主机是否响应。

    fping 与 ping 的不同之处在于,您可以在命令行上指定任意数量的目标,或者指定包含要 ping 的目标列表的文件,或者在命令行上从子网生成范围(我通常使用的最常见形式)。

    例如:

    fping -a -r 0 -qs -g 192.168.1.99/24
    
    • -a :显示活跃的目标
    • -rn:重试次数(默认 3)
    • -q :安静(不显示每个目标/每个 ping 的结果)。这会将输出限制为仅实时 IP。
    • -s:打印最终统计信息,显示发送的 ping 次数、活动 IP 与死亡 IP 的数量等。
    • -g :生成目标列表(仅当未指定 -f 时)。指定目标列表中的起始和结束 IP,或提供 IP 网络掩码“-g 192.168.1.0 192.168.1.25”或“-g 192.168.1.0/24”
    • “targets” :要检查的目标列表(如果没有指定 -f)
    • --help 获取更多选项...

    fping 可从大多数发行版的标准存储库安装。

    apt-get install fping #Ubuntu: installed from the universe repo pool
    zypper install fping #OpenSUSE
    ... etc.
    
    • 0

相关问题

  • 通过命令的标准输出以编程方式导出环境变量[重复]

  • 从文本文件传递变量的奇怪问题

  • 虽然行读取保持转义空间?

  • `tee` 和 `bash` 进程替换顺序

  • 运行一个非常慢的脚本直到它成功

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    模块 i915 可能缺少固件 /lib/firmware/i915/*

    • 3 个回答
  • Marko Smith

    无法获取 jessie backports 存储库

    • 4 个回答
  • Marko Smith

    如何将 GPG 私钥和公钥导出到文件

    • 4 个回答
  • Marko Smith

    我们如何运行存储在变量中的命令?

    • 5 个回答
  • Marko Smith

    如何配置 systemd-resolved 和 systemd-networkd 以使用本地 DNS 服务器来解析本地域和远程 DNS 服务器来解析远程域?

    • 3 个回答
  • Marko Smith

    dist-upgrade 后 Kali Linux 中的 apt-get update 错误 [重复]

    • 2 个回答
  • Marko Smith

    如何从 systemctl 服务日志中查看最新的 x 行

    • 5 个回答
  • Marko Smith

    Nano - 跳转到文件末尾

    • 8 个回答
  • Marko Smith

    grub 错误:你需要先加载内核

    • 4 个回答
  • Marko Smith

    如何下载软件包而不是使用 apt-get 命令安装它?

    • 7 个回答
  • Martin Hope
    user12345 无法获取 jessie backports 存储库 2019-03-27 04:39:28 +0800 CST
  • Martin Hope
    Carl 为什么大多数 systemd 示例都包含 WantedBy=multi-user.target? 2019-03-15 11:49:25 +0800 CST
  • Martin Hope
    rocky 如何将 GPG 私钥和公钥导出到文件 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Evan Carroll systemctl 状态显示:“状态:降级” 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim 我们如何运行存储在变量中的命令? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S 为什么 /dev/null 是一个文件?为什么它的功能不作为一个简单的程序来实现? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 如何从 systemctl 服务日志中查看最新的 x 行 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - 跳转到文件末尾 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla 为什么真假这么大? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis 在一个巨大的(70GB)、一行、文本文件中替换字符串 2017-12-30 06:58:33 +0800 CST

热门标签

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve