您的位置:首頁技術文章
文章詳情頁

LINUX中如何查看某個端口是否被占用的方法

瀏覽:119日期:2024-04-13 14:19:42

之前查詢端口是否被占用一直搞不明白,問了好多人,終于搞懂了,現在總結下:

1.netstat -anp |grep 端口號

如下,我以3306為例,netstat -anp |grep 3306(此處備注下,我是以普通用戶操作,故加上了sudo,如果是以root用戶操作,不用加sudo即可查看),如下圖1:

LINUX中如何查看某個端口是否被占用的方法

圖1中主要看監控狀態為LISTEN表示已經被占用,最后一列顯示被服務mysqld占用,查看具體端口號,只要有如圖這一行就表示被占用了。

2.netstat -nultp(此處不用加端口號)

該命令是查看當前所有已經使用的端口情況,如圖2:

LINUX中如何查看某個端口是否被占用的方法

圖中可以看出我的82端口沒有被占用

3.netstat -anp |grep 82查看82端口的使用情況,如圖3:

LINUX中如何查看某個端口是否被占用的方法

可以看出并沒有LISTEN那一行,所以就表示沒有被占用。此處注意,圖中顯示的LISTENING并不表示端口被占用,不要和LISTEN混淆哦,查看具體端口時候,必須要看到tcp,端口號,LISTEN那一行,才表示端口被占用了

在linux中查看進程占用的端口號

在Linux 上的 /etc/services 文件可以查看到更多關于保留端口的信息。

可以使用以下六種方法查看端口信息。

ss:可以用于轉儲套接字統計信息。 netstat:可以顯示打開的套接字列表。 lsof:可以列出打開的文件。 nmap:是網絡檢測工具和端口掃描程序。 systemctl:是systemd 系統的控制管理器和服務管理器。

以下我們將找出sshd 守護進程所使用的端口號。

方法1:使用 ss 命令

[root@elk3 ~]# ss -tlnp | grep sshd

方法2:使用 netstat 命令

[root@elk3 ~]# netstat -tnlp | grep ssh

方法3:使用 lsof 命令

也可以使用端口號來檢查。

[root@elk3 ~]# netstat -lntp | grep 860

方法4:使用 nmap 命令

[root@elk3 ~]# nmap -sV -p 22 localhost

大部分情況下,以上的輸出不會顯示進程的實際端口號。這時更建議使用以下這個journalctl 命令檢查日志文件中的詳細信息。

[root@elk3 ~]# journalctl | grep -i ssh12月 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 ssh212月 01 21:44:19 elk3 sshd[1106]: pam_unix(sshd:session): session opened for user root by (uid=0)

到此這篇關于LINUX中如何查看某個端口是否被占用的方法的文章就介紹到這了,更多相關LINUX 端口占用內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Linux系統
相關文章:
国产综合久久一区二区三区