如何查看Linux端口状态?

使用 netstat -tulnss -tuln 命令查看监听端口及其状态,lsof -i :端口号 可检查特定端口占用情况,这些命令需 sudo 权限查看所有信息。

🔍 一、ss 命令(推荐首选)

优势:替代传统netstat,执行速度更快,直接读取内核数据。
常用组合

如何查看Linux端口状态?

# 查看所有监听端口(LISTEN)和已建立连接(ESTAB)
ss -tulnp
# 解析输出关键字段:
# -t: TCP端口  -u: UDP端口  -l: 仅监听  -n: 数字形式  -p: 显示进程

输出示例

State   Recv-Q  Send-Q  Local Address:Port  Peer Address:Port
LISTEN  0       128     0.0.0.0:22          0.0.0.0:*        users:(("sshd",pid=1234,fd=3))
ESTAB   0       0       192.168.1.10:22     192.168.1.5:54321

📌 关键解读:

  • LISTEN:服务正在监听(如SSH的22端口)
  • ESTAB:活跃连接(如已建立的SSH会话)

⚙️ 二、netstat 命令(兼容旧系统)

适用场景:老版本系统或习惯经典工具时使用。
操作示例

# 查看TCP/UDP监听端口及关联进程
netstat -tulnp
# 实时监控端口活动(每秒刷新)
netstat -c -tunap

输出字段解析
Proto(协议)、Recv-Q/Send-Q(队列数据)、Local Address(本机IP:端口)、State(状态)、PID/Program(进程信息)


🛠️ 三、lsof 命令(精准定位进程)

核心价值:直接关联端口与进程,适合排查冲突。
关键操作

如何查看Linux端口状态?

# 查看占用80端口的进程
lsof -i :80
# 检查TCP协议22端口
lsof -i TCP:22

输出示例

COMMAND  PID   USER   FD   TYPE DEVICE SIZE/OFF NODE NAME
nginx    567  root    6u  IPv4  12345      0t0  TCP *:http (LISTEN)

💡 提示:NAME列显示LISTEN表示监听中,ESTABLISHED为活动连接。


🌐 四、nmap 扫描(远程/本机探测)

核心用途:检测端口开放状态(本地或远程主机)。
操作步骤

# 安装nmap(未安装时)
sudo apt install nmap  # Debian/Ubuntu
sudo yum install nmap  # CentOS/RHEL
# 扫描本机所有TCP端口
nmap -sT 127.0.0.1
# 快速扫描常用端口(示例远程主机)
nmap -F 192.168.1.100

典型输出

PORT     STATE SERVICE
22/tcp   open  ssh
80/tcp   open  http
3306/tcp open  mysql

⚠️ 注意:STATEopen表示端口开放,filtered可能被防火墙拦截。

如何查看Linux端口状态?


📡 五、连通性测试(telnet/nc

快速验证:测试端口是否可访问(无需完整扫描)。
方法对比
| 工具 | 命令示例 | 适用场景 |
|———|——————————|———————–|
| telnet| telnet 192.168.1.100 3306 | 基础TCP测试(需安装) |
| nc | nc -zv 192.168.1.100 22 | 支持UDP/TCP,无交互 |

结果解读

  • 连接成功 → 显示Connected to...succeeded!
  • 连接失败 → Connection refused(服务未运行)或超时(防火墙拦截)

根据场景选择工具

  1. 日常监控ss -tulnp(高效全面)
  2. 进程关联分析lsof -i :端口号(精准定位)
  3. 远程端口探测nmap -F 目标IP(专业扫描)
  4. 快速连通测试nc -zv IP 端口(即时验证)

📚 引用说明:本文内容基于Linux内核文档(kernel.org)、ss(8)手册页及Nmap官方指南(nmap.org),符合系统管理员通用实践标准。
🔐 安全提示:生产环境操作前请确认权限,避免敏感端口暴露。

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

(0)
酷盾叔的头像酷盾叔
上一篇 2025年6月12日 04:17
下一篇 2025年6月12日 04:20

相关推荐

  • linux 如何格式化cf卡

    Linux 中,若 CF 卡被识别为如 /dev/sde,先输入 fdisk /dev/sde,用 d 命令删除原有分区,再输入 n、p、1 创建新分区,最后用 mkfs.vfat 或 mkfs.ext4 等

    2025年7月13日
    000
  • linux中如何终止程序

    Linux 中,可使用 kill 命令终止程序,如 kill [进程ID],

    2025年7月16日
    100
  • Linux系统如何快速设置有线网络连接?

    Linux系统中配置有线网络可通过图形界面或命令行完成,图形界面通常在系统设置中找到网络选项,启用有线连接并配置IP(DHCP或静态),命令行使用工具如netplan(编辑YAML配置文件)、nmcli或ifup/ifdown,需设置接口名称、IP地址、网关及DNS,完成后重启网络服务生效。

    2025年5月29日
    400
  • 如何在c盘装linux系统分区

    C盘安装Linux系统需先创建新硬盘(如/dev/sdb),用fdisk分区,格式化为ext4,再挂载至指定目录。

    2025年8月2日
    000
  • Linux编程难学吗

    在Linux上编程通常使用GCC/G++编译器和GDB调试器,配合Vim/VS Code等编辑器,通过Make/CMake管理项目,在命令行环境中开发,充分利用开源工具链和库资源。

    2025年6月22日
    200

发表回复

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

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN