如何查看端口连接?

使用 netstat 命令(经典工具)

netstat 是传统网络工具,适合大多数Linux发行版(需安装 net-tools 包):

# 过滤特定端口(如80端口)
sudo netstat -tuln | grep ':80'

参数解析

  • -t:TCP协议
  • -u:UDP协议
  • -l:仅显示监听端口
  • -n:以数字形式显示端口(不解析服务名)
  • -p:显示进程名(需sudo权限)
    输出示例

    Proto Recv-Q Send-Q Local Address  Foreign Address  State       PID/Program name
    tcp        0      0 0.0.0.0:22     0.0.0.0:*        LISTEN      1234/sshd

使用 ss 命令(推荐替代方案)

ss(Socket Statistics)是 netstat 的现代替代品,速度更快,语法类似:

# 查看所有TCP/UDP监听端口
sudo ss -tuln
# 检查特定进程占用的端口(如Nginx)
sudo ss -tuln | grep nginx

优势

  • 直接读取内核数据,效率更高
  • 支持更细粒度的过滤(如 ss -t state established

使用 lsof 命令(查看进程级占用)

lsof(List Open Files)可查看进程打开的文件和端口:

# 查看所有网络端口占用
sudo lsof -i -P -n
# 检查80端口被哪个进程占用
sudo lsof -i :80

参数说明

  • -i:显示网络连接
  • -P:禁用端口服务名解析(显示数字端口)
  • -n:禁用IP地址解析(显示IP而非主机名)
    输出关键列
    COMMAND(进程名)、PID(进程ID)、TYPE(类型)、NODE(协议)、NAME(地址:端口)

使用 nmap 扫描本地端口(安全审计场景)

nmap 通常用于远程扫描,但也可检查本机开放端口:

# 扫描本机所有TCP端口
sudo nmap -sT -p- 127.0.0.1

参数解释

  • -sT:TCP连接扫描
  • -p-:扫描1-65535所有端口
    适用场景
    验证防火墙规则或隐藏端口,比 netstat/ss 更全面(需root权限)。

其他工具补充

  1. fuser 命令
    快速查看端口占用进程(需端口协议):

    sudo fuser 80/tcp  # 显示使用80/TCP的进程PID
  2. systemctl 管理服务
    若端口由systemd服务管理,可直接查询:

    systemctl status sshd | grep -i "listening"  # 检查SSH服务端口

常见问题解决

  • 权限不足
    普通用户可运行 netstat -tulnss -tuln 查看端口状态(但无法显示进程名),需 sudo 获取完整信息。

  • 工具未安装
    安装命令参考:

    # netstat (net-tools)
    sudo apt install net-tools    # Debian/Ubuntu
    sudo yum install net-tools    # CentOS/RHEL
    # ss/lsof (默认预装)
    sudo apt install lsof nmap    # 按需安装
  • 查看指定进程的端口
    结合 pgrepss

    ss -tuln -p | grep $(pgrep nginx)  # 查找Nginx相关端口

总结与最佳实践

  • 日常推荐:优先使用 ss(高效)或 lsof(进程关联性强)。
  • 安全建议
    • 定期检查异常端口(如 netstat -antp 查看所有TCP连接)。
    • 使用 nmap 进行深度扫描,检测未授权服务。
  • 生产环境:结合自动化脚本(如 ss -tuln > port_scan.log 定期归档)。

引用说明: 基于Linux内核文档(kernel.org)及以下工具手册:

  • netstat/ss:Linux Programmer’s Manual
  • lsof:Victor A. Abell 官方文档
  • nmap:Nmap Network Scanning Book (Gordon Lyon)
    操作验证环境:Ubuntu 22.04/CentOS 7,兼容主流Linux发行版。

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

(0)
酷番叔酷番叔
上一篇 2025年7月1日 04:15
下一篇 2025年7月1日 04:25

相关推荐

  • Linux以太网设备如何打开?

    在Linux系统中,以太网设备的“打开”通常指激活网络接口,使其从down状态(禁用)变为up状态(启用),从而能够进行数据收发,这一操作是网络配置的基础步骤,无论是临时激活还是通过配置文件持久化生效,都需要掌握正确的方法,以下将详细介绍Linux以太网设备激活的多种方式及相关注意事项,查看以太网设备状态在激活……

    2025年10月5日
    2600
  • 强制关闭终端会怎样?

    基础退出方法exit 命令在命令行输入 exit 后回车,会立即终止当前Shell会话并关闭终端窗口,适用场景:无后台任务运行时的标准退出方式,快捷键 Ctrl + D按下组合键 Ctrl + D(相当于发送EOF信号),效果等同于 exit 命令,注意:若终端中有未完成的输入(如多行命令未闭合),需多次按 C……

    2025年7月18日
    7600
  • Linux下如何登录到不同的节点服务器?

    在Linux环境中,登录不同节点是日常运维和开发中的常见需求,节点可能指集群中的服务器、虚拟机、容器实例或其他远程主机,不同场景下需采用不同的登录方式,本文将详细介绍Linux登录不同节点的常用方法、配置步骤及注意事项,基础登录方式:SSH远程登录SSH(Secure Shell)是Linux系统最常用的远程登……

    2025年9月24日
    3800
  • 如何安全删除Linux用户的系统文件夹?

    在Linux系统中删除文件夹是一项需要谨慎操作的任务,尤其是涉及系统关键目录或用户重要数据时,错误的删除操作可能导致数据丢失、程序异常甚至系统崩溃,本文将详细介绍删除Linux系统文件夹的正确方法、常用命令、安全注意事项及常见问题处理,帮助用户安全高效地完成文件夹删除操作,删除前的准备工作在执行删除操作前,必须……

    2025年9月13日
    4600
  • Linux如何快速解除USB占用?

    定位占用USB端口的进程识别USB设备路径 lsusb # 查看所有USB设备,记录目标设备的ID(如Bus 001 Device 003)或通过设备描述定位: lsblk # 查看存储设备挂载点(如/dev/sdb1)查找占用进程方法1:通过设备路径lsof /dev/sdb1 # 替换为你的设备路径输出示例……

    2025年8月5日
    4300

发表回复

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

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信