linux 下查看某個端口是否被佔用

在使用Linux系統的過程當中,有時候會遇到端口被佔用而致使服務沒法啓動的狀況。好比HTTP使用80端口,但當啓動Apache時,卻發現此端口正在使用。 html

這種狀況大多數是因爲軟件衝突、或者默認端口設置不正確致使的,此時須要查看究竟哪一個進程佔用了端口,來決定進一步的處理方法。 java

 

查看端口占用狀況的命令:lsof -i

1 [root@www ~]# lsof -i
2  
3 COMMAND PID USER FD TYPE DEVICE SIZE NODE NAME
4 nginx 2333 root 6u IPv4 6242 TCP *:http (LISTEN)
5 nginx 2334 www 6u IPv4 6242 TCP *:http (LISTEN)
6 sshd 2349 root 3u IPv6 6283 TCP *:ndmp (LISTEN)
7 sshd 2349 root 4u IPv6 6286 TCP *:ssh (LISTEN)

這裏返回了Linux當前全部打開端口的佔用狀況。第一段是進程,最後一列是偵聽的協議、偵聽的IP與端口號、狀態。若是端口號是已知的經常使用服務(如80、21等),則會直接顯示協議名稱,如http、ftp、ssh等。 nginx

 

查看某一端口的佔用狀況: lsof -i:端口號

1 [root@www ~]# lsof -i:21
2  
3 COMMAND PID USER FD TYPE DEVICE SIZE NODE NAME
4 pure-ftpd 2651 root 4u IPv4 7047 TCP *:ftp (LISTEN)
5 pure-ftpd 2651 root 5u IPv6 7048 TCP *:ftp (LISTEN)

這裏顯示出21號端口正在被pure-ftpd使用,狀態是listen。 ssh

 

結束佔用端口的進程:killall 進程名

雖然咱們不建議用這種本末倒置的方法來解決衝突問題,但某些狀況下仍是能夠直接結束掉佔用進程的(好比重啓Apache時進程沒有徹底退出,致使重啓失敗) tcp

1 [root@www ~]# killall pure-ftpd

這樣,全部的pure-ftpd進程都會被結束掉。 spa

//============================= .net

http://www.bootf.com/186.html

也可以使用命令:
netstat -apn|grep <端口號>
例如:
Linux代碼  
[root@SonarServer1 user0]# netstat -apn|grep 80  
tcp        0      0 :::80                       :::*                        LISTEN      19408/java    
 找到進程號之後,再使用如下命令查看詳細信息:
ps -aux|grep <進程號>
相關文章
相關標籤/搜索