Linux: 已占用接口

Linux: 已占用接口

  • [1. netstat(适用于旧系统)](#1. netstat(适用于旧系统))
    • [1.1 书中对该命令的介绍](#1.1 书中对该命令的介绍)
  • [2. ss(适用于新系统,替代 netstat)](#2. ss(适用于新系统,替代 netstat))
  • [3. lsof(查看详细进程信息)](#3. lsof(查看详细进程信息))
  • [4. fuser(快速查找占用端口的进程)](#4. fuser(快速查找占用端口的进程))
  • [5. 只查找某个端口是否被占用](#5. 只查找某个端口是否被占用)

1. netstat(适用于旧系统)

powershell 复制代码
netstat -tulnp

参数说明:

  • -t:显示 TCP 端口
  • -u:显示 UDP 端口
  • -l:仅显示 监听中的端口
  • -n:不解析域名,直接显示 IP 和端口号
  • -p:显示 占用端口的进程 ID 和名称

🌰

powershell 复制代码
[root@hecs-230192 ~]# netstat -tulnp
Active Internet connections (only servers)
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      1164/sshd           
tcp        0      0 127.0.0.1:25            0.0.0.0:*               LISTEN      792/master          
tcp6       0      0 :::2181                 :::*                    LISTEN      1410/java           
tcp6       0      0 :::2888                 :::*                    LISTEN      1410/java           
tcp6       0      0 :::3888                 :::*                    LISTEN      1410/java           
tcp6       0      0 :::8080                 :::*                    LISTEN      1410/java           
tcp6       0      0 :::42576                :::*                    LISTEN      1410/java           
tcp6       0      0 :::22                   :::*                    LISTEN      1164/sshd           
tcp6       0      0 ::1:25                  :::*                    LISTEN      792/master          
udp        0      0 0.0.0.0:68              0.0.0.0:*                           549/dhclient        
udp        0      0 127.0.0.1:323           0.0.0.0:*                           497/chronyd         
udp6       0      0 ::1:323                 :::*                                497/chronyd  

🌰

🌰

powershell 复制代码
Proto Recv-Q Send-Q Local Address     Foreign Address   State       PID/Program name
tcp        0      0 0.0.0.0:80        0.0.0.0:*         LISTEN      1234/nginx
tcp        0      0 127.0.0.1:3306    0.0.0.0:*         LISTEN      5678/mysqld

✅ 这里可以看到:

  • 80 端口被 Nginx (PID: 1234) 占用
  • 3306 端口被 MySQL (PID: 5678) 占用

1.1 书中对该命令的介绍

2. ss(适用于新系统,替代 netstat)

powershell 复制代码
ss -tulnp

🔹 ss 比 netstat 更快,占用更少资源,适用于现代 Linux 发行版(如 CentOS 7+、Ubuntu 20+)。

3. lsof(查看详细进程信息)

powershell 复制代码
lsof -i :8080

🔹 -i :8080:查找 8080 端口 是否被占用。

📌 示例输出:

powershell 复制代码
COMMAND  PID  USER  FD  TYPE  DEVICE SIZE/OFF NODE NAME
java     3456 root  6u  IPv6  123456  0t0      TCP *:8080 (LISTEN)

✅ 说明 8080 端口 被 PID 3456 的 Java 进程 占用。

4. fuser(快速查找占用端口的进程)

powershell 复制代码
fuser -v 8080/tcp

[root@hcss-ecs-2ff4 ~]# fuser -v 8080/tcp
                     USER        PID ACCESS COMMAND
8080/tcp:            root       1553 F.... java

✅ 说明 进程 1553 占用了 8080 端口。

5. 只查找某个端口是否被占用

powershell 复制代码
netstat -anp | grep :8080

[root@hcss-ecs-2ff4 ~]# netstat -anp | grep :8080
tcp6       0      0 :::8080                 :::*                    LISTEN      1553/java     

或者:

powershell 复制代码
ss -anp | grep :8080

[root@hcss-ecs-2ff4 ~]# ss -anp | grep :8080
tcp    LISTEN     0      50     [::]:8080               [::]:*                   users:(("java",pid=1553,fd=58))
相关推荐
程序员JerrySUN44 分钟前
驱动开发硬核特训 · Day 21(上篇) 抽象理解 Linux 子系统:内核工程师的视角
java·linux·驱动开发
雨声不在1 小时前
debian切换用户
linux·服务器·debian
不知名。。。。。。。。1 小时前
Linux—— 版本控制器Git
linux·运维·git
两点王爷1 小时前
springboot项目文件上传到服务器本机,返回访问地址
java·服务器·spring boot·文件上传
遇到我又惊又喜2 小时前
佛山大旺高新区3650 M5 ERP服务器维修案例
运维·服务器
内网渗透2 小时前
OpenWrt 与 Docker:打造轻量级容器化应用平台技术分享
linux·docker·容器·openwrt·软路由
易保山3 小时前
MIT6.S081 - Lab11 networking(网络栈)
linux·操作系统·c
安全系统学习3 小时前
网络安全之红队LLM的大模型自动化越狱
运维·人工智能·安全·web安全·机器学习·php
2302_799525743 小时前
【Linux】第十二章 安装和更新软件包
linux·运维·服务器
qq_339282233 小时前
docker打开滚动日志
运维·docker·容器