在命令提示符窗口使用netstat可以查看端口的占用情况,netstat各个参数的含义如下
C:\Users\Administrator>netstat -h
显示协议统计和当前 TCP/IP 网络连接。
NETSTAT [-a] [-b] [-e] [-f] [-n] [-o] [-p proto] [-r] [-s] [-t] [interval]
-a 显示所有连接和侦听端口。
-b 显示在创建每个连接或侦听端口时涉及的可执行程序。
在某些情况下,已知可执行程序承载多个独立的
组件,这些情况下,显示创建连接或侦听端口时涉
及的组件序列。此情况下,可执行程序的名称
位于底部[]中,它调用的组件位于顶部,直至达
到 TCP/IP。注意,此选项可能很耗时,并且在您没有
足够权限时可能失败。
-e 显示以太网统计。此选项可以与 -s 选项结合使用。
-f 显示外部地址的完全限定域名(FQDN)。
-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 选项可用于指定默认的子网。
-t 显示当前连接卸载状态。
interval 重新显示选定的统计,各个显示间暂停的间隔秒数。
按 CTRL+C 停止重新显示统计。如果省略,则 netstat
将打印当前的配置信息一次。
例如:
查看 8080 端口被哪个进程占用
C:\Users\Administrator>netstat -nao | findstr 8080
TCP 0.0.0.0:8080 0.0.0.0:0 LISTENING 3936
TCP 192.168.1.154:59406 113.96.209.105:8080 ESTABLISHED 7828
TCP 192.168.1.154:59478 183.3.235.67:8080 ESTABLISHED 2508
TCP [::]:8080 [::]:0 LISTENING 3936
如果需要结束占用该端口的进程可以使用任务管理或者是使用taskkill命令。
下面介绍使用taskkill命令结束占用端口的进程
C:\Users\Administrator>taskkill /F /PID 3936
成功: 已终止 PID 为 3936 的进程。
taskkill参数具体含义可以使用taskkill /?
查看
ps:如果使用任务管理器通过查找进程id结束进程有点困难可以在命令行中使用tasklist
命令查看进程id对应进程的名字
C:\Users\Administrator>tasklist | findstr 3936
javaw.exe 3936 Console 1 920,296 K