程序启动的过程中,有时候会提示“端口被占用”。如何快速的找到占用该端口的进程?网上有很多种方法,这里自己整理了下,使用DOS命令查询端口并清除端口占用的程序,做个笔记。
windows系统下DOS命令:
1.查看端口号所占用的进程
netstat -a -n 各个端口占用
netstat -aon 各个端口占用和进程PID
netstat -aon|findstr "8080" 查找指定端口所占用的进程,记住进程PID(注意是双引号)
2.查看端口所占用的应用程序
tasklist|findstr "10504" 根据进程PID查找出应用程序(10504是8080端口所占用的进程PID)
3.终止进程
taskkill /pid 10504 /F
或者使用taskkill /f /t /im javaw.exe
重新再查询下,tasklist|findstr "10504" ,若返回为空,则成功终止PID为“10504”的进程。
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 显示当前 配置信息(只显示一次)