端口被占用问题

开发过程中经常会遇到端口号被占用情况,如果想找出被占用端口号的进程,有两种方法

一、通过任务管理器

查看到该端口被哪个进程(对应PID)占用;然后可以打开任务管理器;查看某一PID对应的进程名;如果PID没有显示,菜单》查看》选择列》选中PID即可;得知进程后,我们可以将进程杀掉;修改其使用的端口;

二、通过命令形式如下

netstat -ano

假如我们需要确定谁占用了我们的9050端口

1、Windows平台
在windows命令行窗口下执行:
C:\>netstat -aon|findstr "9050"
TCP    127.0.0.1:9050         0.0.0.0:0              LISTENING       2016

看到了tor占用了该端口,端口被进程号为2016的进程占用,继续执行下面命令:

C:\>tasklist|findstr "2016"
tor.exe                     2016 Console                 0     16,064 K

3、Linux
$netstat -pan|grep 2809
tcp    0   0 0.0.0.0:2809   0.0.0.0:*   LISTEN   9493/java
del.icio.us Tags: aix,windows,tips

netstat命令介绍:

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 显示当前
                配置信息(只显示一次)

### 如何检查和释放被占用端口 #### Linux 系统下的操作方法 在 Linux 中,可以使用 `netstat` 或更现代的工具 `ss` 来检查端口占用情况。以下是具体的操作方式: 1. **查找被占用端口** 使用以下命令来定位特定端口号(例如 9001)的相关信息: ```bash netstat -lnp | grep 9001 ``` 此命令会显示监听该端口的服务及其 PID[^1]。 2. **终止占用端口的进程** 如果确认需要停止某个进程以释放端口,则可以通过其 PID 执行如下命令: ```bash kill -9 <PID> ``` 这里的 `<PID>` 是通过上一步获取到的具体数值。此命令强制结束指定的进程,从而释放端口资源。 3. **处理特殊情况** 若遇到非本用户拥有的进程无法查看详细信息时,提示 `(Not all processes could be identified)`,则需切换至超级用户权限运行上述命令: ```bash sudo netstat -lnp | grep 9001 ``` 对于某些场景下频繁发生端口未正常释放的问题,可能涉及服务配置不当或网络连接异常等情况。例如,在分布式应用环境中,客户端 IP 切换可能导致服务端 FRP 类型的应用未能及时清理旧连接[^2]。 --- #### Windows 系统下的操作方法 针对 Windows 平台上的端口管理需求,可按照以下流程执行: 1. **查询端口状态及对应 PID** 输入以下命令找到目标端口(如 8093)所关联的进程 ID (PID): ```cmd netstat -aon | findstr "8093" ``` 记录返回结果中的最后一列数字作为后续操作依据。 2. **识别具体的程序名称** 基于第一步获得的 PID 查询实际运行的应用名: ```cmd tasklist | findstr "<PID>" ``` 替代其中 `<PID>` 部分为之前记录下来的编号即可得知是由哪款软件占据相应端口。 3. **强行关闭相关任务** 当决定移除干扰项之后便能利用下面这条指令完成最终清除动作: ```cmd taskkill /f /t /pid <PID> ``` 参数 `/f` 表明强制模式;而 `/t` 可连带子线程一同销毁[^3]。 另外还有一种通用做法就是直接调用高级版列表展示全部开放接口详情以便全局掌控当前机器内部运作状况——只需简单敲入一句代码便可达成目的: ```cmd netstat -ano ``` --- #### 跨平台解决方案建议 无论是哪种操作系统环境里头都可能存在由于应用程序崩溃遗留下来却没完全退出干净进而造成冲突的现象存在。因此除了日常维护之外还需要定期排查潜在隐患并且合理规划好各项参数设定防止类似事件再次上演比如调整超时时长或者启用自动回收机制等等措施都是不错的选择方向之一。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值