一、查看已知端口占用情况
比如,我们想知道8080端口的使用情况,或者说被谁占用了,命令如下:
netstat -anp | grep 8080
结果如下:
也可以使用命令:
netstat -tln | grep 8080
结果:
和上个命令对比,少了“2597932/java”,这个显示的是进程号以及被哪个程序所占用。
如果没有被占用,就什么都不显示。
二、查看全部端口占用情况
netstat -anp
# 或者
netstat -tln
显示结果分别如下面:
[root@Cent0S8-FTP sysconfig]# netstat -anp
Active Internet connections (servers and established)
Proto Recv-Q Send-Q Local Address Foreign Address State PID/Program name
tcp 0 0 127.0.0.1:44321 0.0.0.0:* LISTEN 1740/pmcd
tcp 0 0 127.0.0.1:4330 0.0.0.0:* LISTEN 2715/pmlogger
tcp 0 0 0.0.0.0:111 0.0.0.0:* LISTEN 1/systemd
tcp 0 0 0.0.0.0:22 0.0.0.0:* LISTEN 1191/sshd
tcp 0 0 127.0.0.1:631 0.0.0.0:* LISTEN 1196/cupsd
tcp 0 0 192.168.10.111:22 192.168.10.112:56798 ESTABLISHED 3209340/sshd: fangd
tcp 0 0 192.168.10.111:22 192.168.10.112:58794 ESTABLISHED 3330163/sshd: fangd
tcp 32 0 192.168.10.111:35222 8.43.85.13:443 CLOSE_WAIT 3876/gnome-shell
tcp 0 52 192.168.10.111:22 192.168.10.112:56674 ESTABLISHED 3198229/sshd: fangd
tcp6 0 0 ::1:44321 :::* LISTEN 1740/pmcd
tcp6 0 0 ::1:4330 :::* LISTEN 2715/pmlogger
tcp6 0 0 :::111 :::* LISTEN 1/systemd
tcp6 0 0 :::21 :::* LISTEN 1430/vsftpd
tcp6 0 0 :::22 :::* LISTEN 1191/sshd
tcp6 0 0 ::1:631 :::* LISTEN 1196/cupsd
udp 0 0 0.0.0.0:5353 0.0.0.0:* 982/avahi-daemon: r
udp 0 0 192.168.10.111:46722 193.182.111.143:123 ESTABLISHED 985/chronyd
udp 0 0 0.0.0.0:67 0.0.0.0:* 2632/dnsmasq
udp 0 0 192.168.10.111:68 192.168.10.1:67 ESTABLISHED 1176/NetworkManager
udp 0 0 0.0.0.0:111 0.0.0.0:* 1/systemd
udp 0 0 0.0.0.0:45242 0.0.0.0:* 982/avahi-daemon: r
udp 0 0 127.0.0.1:323 0.0.0.0:* 985/chronyd
udp6 0 0 :::5353 :::* 982/avahi-daemon: r
udp6 0 0 :::111 :::* 1/systemd
udp6 0 0 ::1:323 :::* 985/chronyd
udp6 0 0 :::41737 :::* 982/avahi-daemon: r
raw6 0 0 :::58 :::* 7 1176/NetworkManager
Active UNIX domain sockets (servers and established)
Proto RefCnt Flags Type State I-Node PID/Program name Path
unix 2 [ ACC ] SEQPACKET LISTENING 24579 1/systemd /run/systemd/coredump
unix 2 [ ACC ] STREAM LISTENING 29959 967/lsmd /var/run/lsm/ipc/simc
[root@Cent0S8-FTP sysconfig]# netstat -tln
Active Internet connections (only servers)
Proto Recv-Q Send-Q Local Address Foreign Address State
tcp 0 0 127.0.0.1:44321 0.0.0.0:* LISTEN
tcp 0 0 127.0.0.1:4330 0.0.0.0:* LISTEN
tcp 0 0 0.0.0.0:111 0.0.0.0:* LISTEN
tcp 0 0 0.0.0.0:22 0.0.0.0:* LISTEN
tcp 0 0 127.0.0.1:631 0.0.0.0:* LISTEN
tcp6 0 0 ::1:44321 :::* LISTEN
tcp6 0 0 ::1:4330 :::* LISTEN
tcp6 0 0 :::111 :::* LISTEN
tcp6 0 0 :::21 :::* LISTEN
tcp6 0 0 :::22 :::* LISTEN
tcp6 0 0 ::1:631 :::* LISTEN
三、查看具体端口被哪个程序占用
lsof -i :8080
[root@Cent0S8-FTP sysconfig]# lsof -i :8080
COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME
java 2597932 root 45u IPv6 27126054 0t0 TCP *:webcache (LISTEN)
四、kill被占用的进程
我们通过三中的命令得到PID对应的2597932,或者通过命令“netstat -anp | grep 8080”得到的“2597932/java”,这里的2597932都是端口占用的对应进程的进程号,我们杀掉对应进程号即可。
kill -9 2597932
五、检查对应端口是否还在占用
在“四”中,我们kill了对应的进程,那么是否成功了呢,我们可以通过“一”中的命令再查看一下8080端口的使用情况。
netstat -anp | grep 8080
发现没有任何结果,这就说明已经kill掉了对应的进程。
今天的文章Linux查看端口占用情况分享到此就结束了,感谢您的阅读。
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
如需转载请保留出处:https://bianchenghao.cn/12816.html