這篇文章主要講解了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 文件可以查看到更多關于保留端口的信息。
可以使用以下六種方法查看端口信息。
以下我們將找出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 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 ssh3 12月 01 21:44:19 elk3 sshd[1106]: pam_unix(sshd:session): session opened for user root by (uid=0)
看完上述內容,是不是對LINUX中查看某個端口是否被占用的方法有進一步的了解,如果還想學習更多內容,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。