方法1:
Windows:
C:/Users/ewanbao>netstat -aon|findstr
"123"
TCP 127.0.0.1:55123 0.0.0.0:0 LISTENING
5092
TCP 127.0.0.1:55123 127.0.0.1:55124 ESTABLISHED
5092
TCP 127.0.0.1:55124 127.0.0.1:55123 ESTABLISHED
5092
UDP 0.0.0.0:123 *:* 1416
UDP [::]:123 *:* 1416
[注]:执行netstat -aon|findstr
"123"以后,就可以看到5092进程中TCP打开123端口,1416进程打开UDP123端口
C:/Users/ewanbao>tasklist|findstr
"1416"
svchost.exe 1416 Services 0 13,540 K
[注]:执行tasklist|findstr
"1416"后就可以看到是svchost.exe在UDP打开123端口
Linux:
cba001:~ # lsof -i:5300
COMMAND PID USER FD TYPE DEVICE SIZE NODE
NAME
named 26751 root 20u IPv4 64750499 TCP localhost:hacl-hb
(LISTEN)
named 26751 root 21u IPv4 64750501 TCP cba001.eapac:hacl-hb
(LISTEN)
named 26751 root 22u IPv4 64750503 TCP 192.168.0.10:hacl-hb
(LISTEN)
named 26751 root 512u IPv4 64750498 UDP
localhost:hacl-hb
named 26751 root 513u IPv4 64750500 UDP
cba001.eapac:hacl-hb
named 26751 root 514u IPv4 64750502 UDP
192.168.0.10:hacl-hb
[注]:执行lsof
-i:5300以后就可以看到26751进程在TCP和UDP上都打开了5300端口.
cba001:~ # ps -ef|grep 26751
root 10118 26915 0 12:59 pts/8 00:00:00 grep
26751
root 26751 1 0 Jul06 ? 00:02:06
/opt/ipworks/IPWdns/usr/bin/named
[注]:执行ps -ef|grep
26751以后就可以看到是named进程打开了5300端口
查看进程ID:
lsof -w -n -i tcp:8080
fuser -n tcp 8080netstat -anp|grep
:8080[[:blank:]]
杀掉占用端口的进程PID:
kill -9 pidnumber
方法2:
一、在windows操作系统中,查询端口占用和清除端口占用的程序
提升权限后用:netstat -b
或用
1、查询端口占用的进程ID
点击"开始"-->"运行",输入"cmd"后点击确定按钮,进入DOS窗口,接下来分别运行以下命令:
netstat -a -n 各个端口占用
netstat -ano 各个端口占用和进程PID
netstat -aon | findstr "80"
C:\Users\admin>netstat -aon|findstr "80"
TCP 127.0.0.1:9080 0.0.0.0:0 LISTENING 4632
2、查看端口号所对应的应用程序
tasklist | findstr " 4632"
补充: tasklist /fi "pid eq 4632"
GROOVE.EXE 4632 Console 1 84,880 K
很明显,是GROOVE.EXE 占用了80端口,GROOVE.EXE 一个IE的ACTIVEX控件。
3、终止进程
taskkill /pid 4632 /F
或则使用 taskkill /f /t /im GROOVE.exe
再次查询是否成功终止
tasklist
| findstr "4632"
如果成功终止此次执行命令后应返回空.,则表示成功,终止 PID 为 4632 的进程。
二、在Linux操作系统中,查询端口占用和清除端口占用的程序
1、查询端口号占用,根据端口查看进程信息
[root@server2 ~]# lsof -i:80
COMMAND PID USER FD TYPE DEVICE SIZE NODE
NAME
httpd 5014 root 3u IPv4 14346 TCP server2:http (LISTEN)
2、根据进程号查看进程对应的可执行程序
ps -f -p 进程号
# ps -f -p 5014
UID PID PPID C STIME
TTY TIME CMD
root 5014 1 0 17:26
? 00:00:00 /usr/local/apache/bin/httpd -k
3、根据可执行程序查看动态链接
ldd 可执行文件名
ldd /usr/local/apache/bin/httpd
linux-vdso.so.1 => (0x00007fff9dc90000)
libaprutil-0.so.0 => /usr/local/apache/lib/libaprutil-0.so.0
(0x00002af026fcd000)
4、根据端口号得到其占用的进程的详细信息
netstat -tlnp|grep 80
tcp 0 0
192.168.33.10:80 0.0.0.0:* LISTEN 5014/httpd
tcp 0 0
0.0.0.0:48054 0.0.0.0:* LISTEN 5386/java
这一步骤等于刚才上面的一二两个步骤
5、根据端口号查询,查询其占用进程ID
netstat -tlnp|grep 80|awk '{print 7}'|awk -F '/' '{print
1}'
5014
或则是用下面的命令
netstat -pan|grep 80
NETSTAT [-a] [-b] [-e] [-n] [-o] [-p proto] [-r] [-s] [-v]
[interval]
-a 显示所有连接和监听端口。
-b 显
示包含于创建每个连接或监听端口的可执行组件。在某些情况下已知可执行组件
拥有多个独立组件,并且在这些情况下包含于创建连接或监听端口的组件序列被显示。这种情况下,可执行组件名 在底部的 []
中,顶部是其调用的组件,等等,直到 TCP/IP 部分。注意此选项 可能需要很长时间,如果没有足够权限可能失败。 -e 显示以太网统计信息。此选项可以与
-s选项组合使用。 -n 以数字形式显示地址和端口号。
-o 显示与每个连接相关的所属进程 ID。
-p
proto 显示 proto 指定的协议的连接;proto 可以是下列协议之一: TCP、UDP、TCPv6 或
UDPv6。 如果与 -s 选项一起使用以显示按协议统计信息,proto
可以是下列协议之一:
IP、IPv6、ICMP、ICMPv6、TCP、TCPv6、UDP 或
UDPv6。 -r 显示路由表。
-s 显示按协议统计信息。默认地,显示
IP、IPv6、ICMP、ICMPv6、TCP、TCPv6、UDP 和 UDPv6 的统计信息;
-p
选项用于指定默认情况的子集。 -v 与 -b 选项一起使用时将显示包含于
为所有可执行组件创建连接或监听端口的组件。 interval 重新显示选定统计信息,每次显示之间 暂停时间间隔(以秒计)。按 CTRL+C 停止重新 显示统计信息。如果省略,netstat
显示当前 配置信息(只显示一次)
6、一次性的清除占用80端口的程序
lsof -i :80|grep -v "PID"|awk '{print "kill -9",$2}'|sh
7、手工终止进程的运行
kill 5014
如果终止不了,可以强制终止
kill -9 5014
lsof
-i:80
总结:Linux下端口被占用问题解决办法
1.确认端口是否被占用:netstat -tln 9704(被占用端口号)
2.查看该端口被哪个进程占用:lsof -i 9704(被占用端口号)
3.确认没有问题之后,杀!kill -9 pid(占用该端口的进程id)
本文介绍了在Windows和Linux环境下如何查询和释放被占用的端口。包括使用netstat、tasklist、lsof等命令查找占用特定端口的进程,并通过taskkill、kill命令结束这些进程。
1671

被折叠的 条评论
为什么被折叠?



