如何查看端口连接?

使用 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系统中,死循环通常指因代码逻辑错误(如while true未设退出条件)或命令执行异常导致的进程持续占用资源且无法正常退出的情况,以下是针对不同场景的解决方案,操作前请务必确认目标进程,避免误杀系统关键进程,快捷键强制退出按下组合键 Ctrl + C(发送 SIGINT 信号),大多数前台进程会立即……

    2025年6月13日
    3800
  • 如何关闭运行中的虚拟机?,虚拟机还在运行中如何关闭?,关闭虚拟机卡顿怎么办?,运行中的虚拟机如何关闭?,关闭虚拟机前需注意什么?

    在Linux系统中删除虚拟机需要根据使用的虚拟化平台(如VirtualBox、KVM或VMware)选择对应方法,以下是详细操作指南,操作前务必备份虚拟机内重要数据:通用注意事项关闭虚拟机:执行删除前,确保目标虚拟机已完全关闭(非休眠状态),命令行检查:virsh list –all(KVM)或 VBoxMa……

    2025年8月9日
    1500
  • Linux如何查看已挂载U盘?

    命令行方法(推荐)lsblk 命令(最直观) lsblk -f作用:以树状结构列出所有块设备(硬盘、U盘、分区)的详细信息,输出关键字段:NAME:设备名称(如 sdb1),FSTYPE:文件系统类型(如 vfat、ntfs),MOUNTPOINT:挂载路径(如 /media/user/USB),操作示例……

    2025年7月16日
    3100
  • Linux环境下如何正确配置以实现ping通外网?步骤与注意事项详解

    在Linux系统中,ping通外网是排查网络连通性问题的基础操作,涉及本地网络配置、网关、DNS解析、防火墙规则等多个环节,以下是详细步骤及常见问题解决方法,帮助确保Linux主机与外网的正常通信,基础检查:确认本地网络配置首先需确保本地网络接口已正确配置IP地址,且处于活跃状态,使用ip a命令查看网络接口信……

    2025年8月22日
    1300
  • Linux系统如何正确登录?

    本地登录图形界面登录(适用于桌面版Linux)步骤:系统启动后进入登录管理器(如GDM、LightDM),选择用户账户,输入密码,点击”登录”或按回车键进入桌面环境(如GNOME、KDE),注意:部分发行版默认禁用root图形登录(安全考虑),按 Ctrl + Alt + F2~F6 可切换到命令行终端,命令行……

    2025年6月23日
    3100

发表回复

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

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信