Linux如何快速检查端口连通?

使用 telnet 命令

原理:通过TCP协议模拟客户端连接目标端口。
安装(如未预装):

sudo apt install telnet  # Debian/Ubuntu
sudo yum install telnet  # CentOS/RHEL

命令格式

telnet <目标IP> <端口号>

示例

telnet 192.168.1.100 80

结果解读

  • 连接成功 → 显示 Connected to 192.168.1.100(按 Ctrl+] 退出)。
  • 连接失败 → 显示 Connection refused(端口关闭)或超时(防火墙拦截)。

使用 nc (netcat) 命令

原理:多功能网络工具,支持TCP/UDP端口测试。
安装

sudo apt install netcat  # Debian/Ubuntu
sudo yum install nc      # CentOS/RHEL

命令格式

nc -zv <目标IP> <端口号>  # -z: 扫描模式, -v: 详细输出

示例

nc -zv example.com 443

结果解读

  • 成功 → Connection to example.com 443 port [tcp/https] succeeded!
  • 失败 → Connection timed outConnection refused

使用 nmap 命令

原理:专业端口扫描工具,可检测端口状态及服务类型。
安装

sudo apt install nmap  # Debian/Ubuntu
sudo yum install nmap  # CentOS/RHEL

命令格式

nmap -p <端口号> <目标IP>

示例

nmap -p 22 192.168.1.100

结果解读

  • 开放 → STATE: open
  • 关闭 → STATE: closed
  • 过滤 → STATE: filtered(被防火墙拦截)。

使用 curl 测试HTTP/HTTPS端口

原理:通过HTTP协议检测Web服务端口。
命令格式

curl -I http://<目标IP>:<端口>  # -I: 仅显示响应头
curl -I https://<目标IP>:<端口> --insecure  # 忽略SSL证书验证

示例

curl -I http://example.com:8080

结果解读

  • 成功 → 返回HTTP状态码(如 200 OK)。
  • 失败 → Connection refused 或超时。

使用Bash内置 /dev/tcp

原理:无需额外工具,利用Bash的虚拟设备文件。
命令格式

timeout 3 bash -c "echo > /dev/tcp/<目标IP>/<端口>" && echo "Open" || echo "Closed"

示例

timeout 3 bash -c "echo > /dev/tcp/192.168.1.100/3306" && echo "Open" || echo "Closed"

结果解读

  • 输出 Open 表示端口可达,Closed 表示不可达。

使用 ssh 测试SSH端口

原理:专用于检测SSH服务(默认22端口)。
命令格式

ssh -v -p <端口> user@<目标IP>  # -v: 详细模式

示例

ssh -v -p 2222 user@192.168.1.100

结果解读

  • 成功 → 显示密钥交换信息。
  • 失败 → Connection refused 或超时。

总结与建议

场景 推荐工具 优势
快速TCP端口检查 telnetnc 轻量级、结果直观
批量扫描或服务探测 nmap 功能全面、支持协议识别
HTTP/HTTPS服务检测 curl 模拟真实请求、验证应用层响应
无外部工具的简易检查 Bash /dev/tcp 无需安装、脚本友好
SSH服务专项检测 ssh -v 直接验证登录流程

注意

  • 连接失败时,需排查:
    • 目标服务是否运行(systemctl status <服务名>)。
    • 防火墙规则(sudo ufw statusiptables -L)。
    • 云服务器安全组策略。
  • 部分工具需root权限才能扫描特权端口(1-1024)。

引用说明

  • telnetnc 用法参考自 GNU Netcat 文档。
  • nmap 参数规范依据 Nmap 官方手册。
  • Bash /dev/tcp 实现原理详见 Bash 参考手册 “Redirection” 章节。

原创文章,发布者:酷番叔,转转请注明出处:https://cloud.kd.cn/ask/7882.html

(0)
酷番叔酷番叔
上一篇 2025年7月19日 05:09
下一篇 2025年7月19日 05:19

相关推荐

  • Linux 7如何重装Linux?详细步骤与方法指南

    重装Linux系统(以CentOS 7为例)是解决系统故障、升级版本或清理数据的常用操作,整个过程需谨慎操作,避免数据丢失,以下是详细步骤及注意事项:准备工作重装前需完成以下准备,确保操作顺利:备份重要数据:将用户目录(/home)、配置文件(如/etc/nginx、/etc/my.cnf)、应用数据(数据库……

    2025年9月28日
    9800
  • Linux启动进程的具体方法与步骤有哪些?

    Linux系统中,进程是程序执行的基本单位,启动进程是系统运行的核心操作之一,理解Linux如何启动进程,需要从进程的基本概念、启动方式、底层机制及管理工具等多个维度展开,进程的基本概念与属性在Linux中,进程是一个动态执行的实体,拥有独立的虚拟地址空间、系统资源(如文件描述符、内存空间)和执行状态,每个进程……

    2025年9月30日
    7300
  • linux如何umount

    Linux中,可以使用umount命令卸载文件系统,umount /dev/

    2025年8月17日
    10200
  • Linux如何配置NTP实现时间同步?

    在Linux系统中,时间同步是确保系统日志、安全认证、分布式任务调度等正常工作的关键环节,NTP(Network Time Protocol)作为一种时间同步协议,能够通过网络将本地系统时间与标准时间源对齐,确保时间的高精度和一致性,本文将详细介绍在Linux系统中配置NTP同步的完整步骤,包括安装NTP服务……

    2025年9月19日
    82400
  • 启动前最容易忽略什么?

    Linux作为开源操作系统的代表,广泛应用于个人电脑、服务器和嵌入式设备,启动Linux看似简单,但不同场景下的操作差异较大,本文将详细解析启动Linux的多种方式,涵盖从硬件准备到系统加载的全流程,帮助访客安全、高效地完成操作,硬件兼容性检查确认设备支持Linux(多数x86电脑兼容,ARM设备如树莓派需专用……

    2025年7月9日
    13700

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信