前言
如何确定端口是否在Linux或类unix系统下占用?怎么检查哪些端口正在Linux服务器上被占用?Linux系统如何使用命令行检查端口是否已经在占用?
![7e0ecc48a2caecec97b9da9c7ea906c0.png](https://i-blog.csdnimg.cn/blog_migrate/c704d64178c468fc65f512427894f3ee.jpeg)
Linux端口占用查询
查询哪些端口正在服务器的网络接口上被占用是非常重要的工作。您需要查询打开端口以检测入侵。除了入侵之外,出于故障排除的目的,可能有必要检查服务器上的其他应用程序是否已经使用了某个端口。例如,您可以在同一系统上安装Apache和Nginx服务器。因此,有必要了解Apache或Nginx是否使用TCP端口80或443。本教程提供了使用netstat、nmap和lsof命令查询正在使用的端口并查看正在使用该端口的应用程序的步骤。
如何查询端口是否在使用中:
检查Linux上被占用的端口和应用程序:
Step1: 打开终端
Step2: 执行以下任意一条命令查看被占用的端口
查看端口22是否被占用:
较新版本的Linux使用以下查询命令:
方法1: 使用lsof命令查询占用端口
先安装lsof命令
RHEL/CentOS系统:
![802a81c8537dbceb956720a63073687e.png](https://i-blog.csdnimg.cn/blog_migrate/66dec5a611f0153db7a6d9c7df1041ec.jpeg)
使用lsof命令查询占用端口
Debian/Ubuntu系统安装lsof命令
使用语法如下
OpenBSD
![bf0637843cf2ac888f3de2edaaf279ba.png](https://i-blog.csdnimg.cn/blog_migrate/a2a5a1c5e45eac33bd1b540b2032c62e.jpeg)
通过lsof查询端口被占用的情况
看到类似这样的输出结果:
sshd是进程名字
TCP 22表示sshd进程占用了TCP 22端口,正在监听中(LISTEN)
1243表示sshd进程号
方法二:使用netstat查询被占用的端口号
较新的Linux发行版已经不再默认集成netstat命令,而是使用新命令ss取代了。
如果要使用netstat命令,需要手动安装net-tools套件:
RHEL/CentOS系统安装net-tools套件,执行以下命令:
Debian/Ubuntu系统执行以下命令:
![f3df1344e85fbde4c2a63b1301fbfe5e.png](https://i-blog.csdnimg.cn/blog_migrate/9a6c8e6b7b973c48f422cba95f1d2048.jpeg)
Linux安装netstat命令用于查询被占用的端口号
您可以使用netstat查询被占用的端口和应用程序,如下所示。
执行以下命令查询:
![f430ce72bf9ba07e46e13524976661e6.png](https://i-blog.csdnimg.cn/blog_migrate/efe3364e3ee2f9c11480ce2d9316b68c.jpeg)
使用netstat查询被占用的端口和应用程序
在Linux上,netstat命令已经废弃了一段时间。因此,你需要使用ss命令如下:
或者:
![367458b0b8fae64d7eb0bdea2da957b1.png](https://i-blog.csdnimg.cn/blog_migrate/f1cd3810585c5f21ad81c332ee197dff.jpeg)
使用ss命令查询被占用的端口号
其中ss命令选项如下:
-t : 只显示Linux上的TCP套接字
-u : 在Linux上只显示UDP套接字
-l : 监听套接字。例如,TCP端口22由SSHD服务器打开。
-p : 列出打开套接字的进程名
-n : 不要解析服务名称,即不要使用DNS
FreeBSD/MacOS X netstat 语法
FreeBSD/MacOS X查询被占用的端口
或者
OpenBSD netstat 语法
OpenBSD查询被占用的端口
或者
方法三:使用`nmap`命令查询Linux被占用的端口
默认情况下,Linux发行版并没有默认安装nmap命令,
CentOS系统安装nmap
Ubuntu系统安装nmap
使用nmap查询本机被占用的端口
查询Linux系统被占用的UDP端口
查询Linux系统被占用的TCP端口
![959b1fb226f0082dab435017b9da1a27.png](https://i-blog.csdnimg.cn/blog_migrate/abb0fdd6b069a0568c15ec8fea01835d.jpeg)
使用nmap命令查询Linux被占用的端口
你可以同时查询被占用的TCP和UDP端口
结论:
本教程解释了如何在Linux系统上使用命令行查询TCP或者UDP端口是否被占用。有关更多信息,请参见nmap命令和lsof命令页面