lsof
lsof(list open files)是一个列出当前系统打开文件的工具。
lsof 查看端口占用语法格式:
lsof -i:端口号
实例
查看服务器 80 端口的占用情况:
lsof -i 需要 root 用户的权限来执行,如果没有root权限,只能查看当前用户的程序端口占用情况。
sudo lsof -i:80
soarli@soarli-virtual-machine:~$ sudo lsof -i:80
[sudo] soarli 的密码:
COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME
nginx 946 root 6u IPv4 39789 0t0 TCP *:http (LISTEN)
nginx 946 root 7u IPv6 39790 0t0 TCP *:http (LISTEN)
nginx 947 www-data 6u IPv4 39789 0t0 TCP *:http (LISTEN)
nginx 947 www-data 7u IPv6 39790 0t0 TCP *:http (LISTEN)
nginx 948 www-data 6u IPv4 39789 0t0 TCP *:http (LISTEN)
nginx 948 www-data 7u IPv6 39790 0t0 TCP *:http (LISTEN)
可以看到 80 端口已经被轻 nginx 服务占用。
lsof输出各列信息的意义如下:
COMAND:进程的名称
PID:进程标识符
USER:进程所有者
FD:文件描述符,应用程序通过文件描述符识别该文件。如cwd、txt等
TYPE:文件类型,如DIR、REG等
DEVICE:指定磁盘的名称
SIZE:文件的大小
NODE:索引节点(文件在磁盘上的标识)
NAME:打开文件的确切名称
更多 lsof 的命令如下:
lsof -i:8080:查看8080端口占用
lsof abc.txt:显示开启文件abc.txt的进程
lsof -c abc:显示abc进程现在打开的文件
lsof -c -p 1234:列出进程号为1234的进程所打开的文件
lsof -g gid:显示归属gid的进程情况
lsof +d /usr/local/:显示目录下被进程开启的文件
lsof +D /usr/local/:同上,但是会搜索目录下的目录,时间较长
lsof -d 4:显示使用fd为4的进程
lsof -i -U:显示所有打开的端口和UNIX domain文件
netstat
netstat -tunlp
用于显示 tcp,udp 的端口和进程等相关情况。
netstat 查看端口占用语法格式:
netstat -tunlp | grep 端口号
-t (tcp) 仅显示tcp相关选项
-u (udp)仅显示udp相关选项
-n 拒绝显示别名,能显示数字的全部转化为数字
-l 仅列出在Listen(监听)的服务状态
-p 显示建立相关链接的程序名
例如查看 8000 端口的情况,使用以下命令:
soarli@soarli-virtual-machine:~$ sudo netstat -tunlp | grep 80
tcp 0 0 0.0.0.0:80 0.0.0.0:* LISTEN 946/nginx: master p
tcp6 0 0 :::80 :::* LISTEN 946/nginx: master p
更多命令:
netstat -ntlp //查看当前所有tcp端口
netstat -ntulp | grep 80 //查看所有80端口使用情况
netstat -ntulp | grep 3306 //查看所有3306端口使用情况
kill
在查到端口占用的进程后,如果你要杀掉对应的进程可以使用 kill 命令:
kill pid
如上实例,我们看到 80 端口对应的 PID 为 946,使用以下命令杀死进程:
kill 946
如果实在杀不掉,可以尝试使用
kill -l PID
-l选项告诉kill命令用好像启动进程的用户已注销的方式结束进程。当使用该选项时,kill命令也试图杀死所留下的子进程。但这个命令也不是总能成功--或许仍然需要先手工杀死子进程,然后再杀死父进程。
如果实在杀不掉,可以尝试使用强制杀掉
kill -9 PID
上实例:kill -9 946
更多关于linux查看系统进程、kill命令,马上再总结一篇。
参考资料:
https://www.runoob.com/w3cnote/linux-check-port-usage.html
https://blog.csdn.net/marujunyy/article/details/8466264
版权属于:soarli
本文链接:https://blog.soarli.top/archives/34.html
转载时须注明出处及本声明。