在使用Linux系統的過程當中,有時候會遇到端口被佔用而致使服務沒法啓動的狀況。好比HTTP使用80端口,但當啓動Apache時,卻發現此端口正在使用。nginx
這種狀況大多數是因爲軟件衝突、或者默認端口設置不正確致使的,此時須要查看究竟哪一個進程佔用了端口,來決定進一步的處理方法。shell
查看端口占用狀況的命令:lsof -i
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 |
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]