AIX查看某个端口被哪个进程占用并处理

在AIX系统管理中,当遇到启动进程提示端口被占用的问题,如WebSphere的9090端口,可以使用netstat命令找到被监听的端口。然而,只知道端口被占用并不足以解决问题,需要找出占用该端口的具体进程。通过rmsock命令结合PCB(Protocol Control Block)地址,特别是对于tcp连接,可以定位到并结束占用端口的进程,从而避免修改端口设置的复杂操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

问题描述:

在系统管理过程中经常遇到的情况就是在启动某个进程时,会提示端口被占用。如启动WebSphere管理控制台时经常碰到9090端口被占用。用 netstat -an | grep 9090 可以看到该端口正被监听,但却不知道是哪个进程占用了该端口,当然也可以改变端口但比较麻烦。如果能找到是哪个进程占用了该端口,把这个进程kill掉就可以了。


问题解决

1. netstat -Aan|grep <portnumber>
找到该端口连接对应的 PCB/ADDR 和连接的协议类型。

注:PCB ----Protocol Control Block


2. 如果是 tcp 连接,则 rmsock <PCB/ADDR> tcpcb

如果是 udp 连接,则 rmsock <PCB/ADDR> inpcb


下面我们以 telnet 服务所使用的 23 号端口为例,说明该方法:
#netstat -Aan|grep 23
f1000200019ce398 tcp 0 0 *.23 *.* LISTEN

可以看到 PCB/ADDR 为 f1000200019ce398 ,且协议类型为 tcp 。


#rmsock f1000200019ce398 tcpcb
The socket 0x19ce008 is being held by proccess 185006 (inetd).
命令报告该端口正在被 inetd 进程使用, PID 为 185006 。
注意: rmsock 命令需要 root 权限执行。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值