Linux如何查看程序占用端口?

使用 netstat 命令(经典工具)

适用场景:快速查看所有活跃连接和监听端口。
命令示例

sudo netstat -tulnp
  • 参数解析
    -t:TCP协议
    -u:UDP协议
    -l:仅显示监听端口
    -n:以数字形式显示端口(不解析服务名)
    -p:显示进程名和PID
  • 输出示例
    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
    tcp6       0      0 :::80          :::*             LISTEN   5678/nginx

    关键列:
    Local Address0.0.0:22 表示监听所有IP的22端口
    PID/Program name → 进程ID和程序名(如 sshd


使用 ss 命令(netstat 的现代替代)

优势:执行速度更快,语法更简洁。
命令示例

sudo ss -tulnp
  • 参数与输出:与 netstat 类似,但格式更紧凑。
  • 过滤特定端口(如查看80端口):
    sudo ss -tulnp 'sport = :80'

使用 lsof 命令(查看文件与端口关联)

适用场景:精确查看指定程序或端口的使用情况。
常用操作

  1. 查看所有监听端口

    sudo lsof -i -P -n | grep LISTEN
    • -i:显示网络连接
    • -P:禁用端口服务名解析(显示数字端口)
    • -n:禁用IP地址解析(显示数字IP)
  2. 查看指定程序(如nginx)的端口

    sudo lsof -i -P -n | grep nginx
  3. 查看指定端口(如3306)的进程

    sudo lsof -i :3306

使用 fuser 命令(通过端口查进程)

适用场景:直接根据端口号定位进程。
命令示例

sudo fuser 80/tcp
  • 输出80/tcp: 5678 → 表示TCP 80端口被PID为5678的进程占用。

通过 /proc 文件系统(底层信息)

原理:Linux的进程信息存储在 /proc 目录中。
操作步骤

  1. 先用 sslsof 获取端口对应的PID(如PID 5678)。
  2. 查看该进程打开的端口:
    ls -l /proc/5678/fd | grep socket:

⚠️ 常见问题与解决方案

  1. 权限不足

    • 若命令无输出,需添加 sudo 提权(普通用户无法查看系统进程)。
  2. 命令未找到

    • 安装缺失工具:
      # netstat/ss
      sudo apt install net-tools iproute2  # Debian/Ubuntu
      sudo yum install net-tools iproute   # CentOS/RHEL
      # lsof/fuser
      sudo apt install lsof psmisc         # Debian/Ubuntu
      sudo yum install lsof psmisc         # CentOS/RHEL
  3. 端口显示为 :::800.0.0:80

    • 表示IPv6监听,0.0.0 表示IPv4监听(所有网卡)。

总结建议

  • 首选工具:日常使用 ss(高效)或 lsof(功能全面)。
  • 安全提示
    • 关闭未授权的端口(通过防火墙或终止进程)。
    • 定期检查可疑连接(如 ESTABLISHED 状态的未知IP)。
  • 自动化监控:结合脚本(如 cron 定时运行 ss -tuln)记录端口使用情况。

引用说明

  • 命令文档参考 Linux man 手册(如 man ss, man lsof)。
  • 网络协议规范依据 IETF RFC 标准(如 TCP/UDP 端口定义)。
  • 系统级实现参考 Linux 内核文档(/proc 文件系统)。

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

(0)
酷番叔酷番叔
上一篇 2025年7月8日 07:19
下一篇 2025年7月8日 07:37

相关推荐

  • Linux怎样安全断开恶意客户端?

    通过 ss + kill 组合(推荐)适用场景:精准关闭指定IP或端口的连接,步骤:查找目标连接:ss -tpan | grep '客户端IP:端口' # 替换为实际IP和端口-t:仅TCP连接-p:显示进程信息-n:禁用域名解析(加速查询)输出示例:ESTAB 0 0 192.168.1.5……

    2025年6月23日
    1400
  • 如何删除小写m并备份文件?

    在Linux系统中去除字符 m 的操作需根据具体场景选择合适方法,以下是专业且安全的实践指南:删除文件内容中的 m 字符方法1:使用 sed 流编辑器(推荐)# 删除所有大写 M(保留大小写敏感性)sed -i 's/M//g' filename.txt# 同时删除大小写 msed -i &#3……

    2025年6月15日
    1700
  • 如何用光盘安装Linux并下载视频教程?

    为什么选择光盘安装Linux?光盘安装是最稳定可靠的Linux安装方式之一,尤其适合:无U盘或网络环境差的用户需要反复安装/修复系统的场景确保安装文件无篡改(通过校验ISO完整性)📌 专业提示:根据Linux基金会2023年报告,光盘安装的成功率比U盘高15%,且能避免U盘兼容性问题,准备工作清单工具要求注意事……

    2天前
    700
  • 为什么无法打开配置文件怎么办?

    使用 pwd 命令(最常用)命令:pwd作用:pwd(Print Working Directory)直接输出当前路径的绝对路径(完整路径),示例:user@server:~$ pwd/home/user # 输出结果特点:简单、无参数,适合所有用户,绝对路径以根目录 开头,清晰展示完整位置,通过 Shell……

    2025年7月10日
    1000
  • Oracle数据库卡顿如何优化?

    *命令行登录:使用 SQLPlus***SQLPlus** 是Oracle官方命令行工具,适合服务器环境或远程连接,步骤 1:配置环境变量# 加载Oracle环境变量(根据实际安装路径调整)source /u01/app/oracle/product/19.0.0/dbhome_1/bin/oracle_env……

    1小时前
    100

发表回复

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

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信