首页 > 运维 > linux运维 > 正文

Linux怎么查看进程使用的端口号

P粉602998670
发布: 2025-09-10 09:10:01
原创
797人浏览过
答案是使用netstat、ss或lsof命令可查看Linux进程占用的端口。首先推荐ss命令,如ss -tulnp | grep 8080,能快速显示监听端口及对应进程;其次netstat -tulnp | grep 8080用法类似,但速度较慢;lsof -i :8080可精确查看指定端口的进程信息,包含PID和命令名;若已知PID,可用lsof -p 1234或netstat -tulnp | grep 1234反查端口;无权限时建议使用sudo或检查/proc/<PID>/cmdline文件确认进程身份;除TCP/UDP外,SCTP等协议需额外参数支持。

linux怎么查看进程使用的端口号

查看Linux进程使用的端口号,其实方法很多,关键在于你想要多详细的信息,以及你习惯用哪个命令。最简单粗暴的,当然是

netstat
登录后复制
或者
ss
登录后复制
,但有时候
lsof
登录后复制
也能派上大用场。

解决方案

  1. 使用

    netstat
    登录后复制
    命令:

    最常用的方法,简单直接。

    netstat -tulnp | grep <端口号或进程名>
    登录后复制
    • -tulnp
      登录后复制
      :
      t
      登录后复制
      显示 TCP 连接,
      u
      登录后复制
      显示 UDP 连接,
      l
      登录后复制
      显示监听端口,
      n
      登录后复制
      以数字形式显示地址和端口 (不进行域名解析),
      p
      登录后复制
      显示进程 ID 和进程名。
    • grep <端口号或进程名>
      登录后复制
      : 过滤结果,可以根据端口号或者进程名来查找。例如,想找8080端口被哪个进程占用,就用
      grep 8080
      登录后复制
      。想找nginx进程占用的端口,就用
      grep nginx
      登录后复制

    示例:

    netstat -tulnp | grep 8080
    登录后复制

    输出类似:

    tcp        0      0 0.0.0.0:8080            0.0.0.0:*               LISTEN      1234/java
    登录后复制

    这里

    1234
    登录后复制
    就是进程ID (PID),
    java
    登录后复制
    是进程名。

  2. 使用

    ss
    登录后复制
    命令:

    ss
    登录后复制
    netstat
    登录后复制
    的替代品,速度更快,效率更高。

    ss -tulnp | grep <端口号或进程名>
    登录后复制

    参数含义和

    netstat
    登录后复制
    类似,用法也差不多。

    示例:

    ss -tulnp | grep 8080
    登录后复制

    输出结果也类似:

    tcp   LISTEN  0      128    *:8080                *:*                   users:(("java",pid=1234,fd=72))
    登录后复制
  3. 使用

    lsof
    登录后复制
    命令:

    SpeakingPass-打造你的专属雅思口语语料
    SpeakingPass-打造你的专属雅思口语语料

    使用chatGPT帮你快速备考雅思口语,提升分数

    SpeakingPass-打造你的专属雅思口语语料 25
    查看详情 SpeakingPass-打造你的专属雅思口语语料

    lsof
    登录后复制
    (List Open Files) 功能更强大,可以查看进程打开的所有文件,当然也包括端口。

    lsof -i :<端口号>
    登录后复制
    • -i :<端口号>
      登录后复制
      : 指定端口号。

    示例:

    lsof -i :8080
    登录后复制

    输出类似:

    COMMAND  PID   USER   FD   TYPE DEVICE SIZE/OFF NODE NAME
    java    1234   user   72u  IPv6 12345      0t0  TCP *:http-alt (LISTEN)
    登录后复制

    这里的

    1234
    登录后复制
    同样是进程ID。

  4. 根据PID查找端口:

    有时候你已经知道进程ID,想反过来查它占用的端口。

    netstat -tulnp | grep <PID>
    登录后复制

    或者

    lsof -p <PID> | grep LISTEN
    登录后复制

    示例:

    netstat -tulnp | grep 1234
    登录后复制
    lsof -p 1234 | grep LISTEN
    登录后复制

为什么
netstat
登录后复制
有时候不好使?

netstat
登录后复制
虽然经典,但它依赖于
/proc
登录后复制
文件系统,而且在某些情况下可能无法提供所有信息。
ss
登录后复制
命令通常更快更全面,因为它直接从内核获取信息。所以,如果
netstat
登录后复制
没查到,不妨试试
ss
登录后复制

Linux怎么查看进程使用的端口号

如何确定端口被哪个程序占用,但没有权限?

如果你的权限不够,无法直接运行

netstat -tulnp
登录后复制
,可能会遇到权限问题。这时候,可以尝试使用
sudo
登录后复制
,或者联系系统管理员。另一种方法是查看
/proc/<PID>/cmdline
登录后复制
文件,前提是你知道PID。虽然不能直接查到端口,但可以间接判断是不是你想找的进程。

Linux怎么查看进程使用的端口号

除了TCP和UDP,还有其他类型的端口吗?

虽然TCP和UDP是最常见的,但Linux也支持其他协议,比如SCTP (Stream Control Transmission Protocol)。

netstat
登录后复制
ss
登录后复制
默认只显示TCP和UDP,如果要查看其他协议,需要指定相应的参数。例如,
ss -at
登录后复制
会显示所有 TCP 连接,包括已经建立的和正在监听的。

以上就是Linux怎么查看进程使用的端口号的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号