导读 这篇文章主要介绍了LINUX中如何查看某个端口是否被占用的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧。
1.netstat -anp |grep 端口号
如下,我以3306为例,netstat -anp |grep 3306(此处备注下,我是以普通用户操作,故加上了sudo,如果是以root用户操作,不用加sudo即可查看),如下图1:
图1中主要看监控状态为LISTEN表示已经被占用,最后一列显示被服务mysqld占用,查看具体端口号,只要有如图这一行就表示被占用了。
2.netstat -nultp(此处不用加端口号)
该命令是查看当前所有已经使用的端口情况,如图2:
图中可以看出我的82端口没有被占用
3.netstat -anp |grep 82查看82端口的使用情况,如图3:
可以看出并没有LISTEN那一行,所以就表示没有被占用。此处注意,图中显示的LISTENING并不表示端口被占用,不要和LISTEN混淆哦,查看具体端口时候,必须要看到tcp,端口号,LISTEN那一行,才表示端口被占用了
在linux中查看进程占用的端口号
在Linux 上的 /etc/services 文件可以查看到更多关于保留端口的信息。
可以使用以下六种方法查看端口信息。
ss:可以用于转储套接字统计信息。
netstat:可以显示打开的套接字列表。
lsof:可以列出打开的文件。
nmap:是网络检测工具和端口扫描程序。
systemctl:是systemd 系统的控制管理器和服务管理器。
以下我们将找出sshd 守护进程所使用的端口号。
方法1:使用 ss 命令
# ss -tlnp | grep sshd
方法2:使用 netstat 命令
# netstat -tnlp | grep ssh
方法3:使用 lsof 命令
也可以使用端口号来检查。
# netstat -lntp | grep 860
方法4:使用 nmap 命令
# nmap -sV -p 22 localhost
大部分情况下,以上的输出不会显示进程的实际端口号。这时更建议使用以下这个journalctl 命令检查日志文件中的详细信息。
# journalctl | grep -i ssh
12月 01 21:43:36 elk3 systemd[1]: Starting OpenSSH server daemon…
12月 01 21:43:36 elk3 sshd[860]: Server listening on 0.0.0.0 port 22.
12月 01 21:43:36 elk3 sshd[860]: Server listening on :: port 22.
12月 01 21:43:36 elk3 systemd[1]: Started OpenSSH server daemon.
12月 01 21:44:19 elk3 sshd[1106]: Accepted password for root from 192.168.122.1 port 49316 ssh2
12月 01 21:44:19 elk3 sshd[1106]: pam_unix(sshd:session): session opened for user root by (uid=0)
到此这篇关于LINUX中如何查看某个端口是否被占用的方法的文章就介绍到这了。
原文来自:https://www.jb51.net/article/191517.htm
本文地址:https://www.linuxprobe.com/linux-port-check.html
编辑:张@宇,审核员:逄增宝
Linux命令大全:https://www.linuxcool.com/
Linux系统大全:https://www.linuxdown.com/
红帽认证RHCE考试心得:https://www.rhce.net/
为您推荐一些与本文相关的文章:
捷讯:邢海涛12月12日深圳顺利通过RHCE认证。
细述docker容器中创建SSH服务镜像
奇葩漏洞:一键入侵你的Linux系统。
Android Q首批升级厂商名单公布
华为手机变身交通卡,公交地铁都能刷
正则表达式基础
《Visual Basic从入门到精通(第5版)》pdf版电子书免费下载
NVIDIA发布了418.52.10 Linux beta驱动程序
Arch Linux:纯粹主义者的最后避难所!
oracle连接查询详解