在使用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]