linux 查看端口被佔用狀況

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

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

 

查看端口占用狀況的命令: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等。ssh

 

查看某一端口的佔用狀況: 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。socket

 

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

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

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

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

使用netstat

netstat -pan|grep port
netstat -tln|grep prot
netstate:
     -p, --program
       Show the PID and name of the program to which each socket belongs.
     -n, --numeric , 
       Show numerical addresses instead of trying to determine symbolic host, port or user names.
      -t: [--tcp|-t] [--udp|-u] [--raw|-w] [delay]
      -l:  [--listening|-l]
相關文章
相關標籤/搜索