莫大人

程序端口被占用分析

这几天弄测试环境和SIT环境。在一台服务器上部署了多台tomcat,后面重启的时候总是报dubbo服务的端口被占用。于是开始查

被占用的端口为20883

1.查看端口情况

netstat -apn

 

通过上面的命令我们可以看到本地 20883端口是被使用了的,对应的进程号及进程是 13323/java

2.我们通过管道过滤下可以看得更清楚

netstat -apn|grep 20883

可以发现本地端口使用有一个20883,进程13323/java

远程端口使用有2个,进程分别为 13323/java , 12879/java

分析知道我部署的应用时存在dubbo+zookeeper的,上面的 20883 是zookeeper的默认端口,

也就是说远程端口使用的 20883 是zookeeper对外提供的默认端口,有2个进程是由于我部署了2台tomcat应用。

 3.分析端口

netstat -apn|grep "10.24.64.151"

 

可以看到10.24.64.151这台服务器的 20883 端口被java程序的不同进程号使用2次。可以明确是2台tomcat在使用。

 

那么本地使用的20883端口呢,将20883拿到我本地项目中搜索

 

 继续搜索在哪里使用

4.解决问题

 找到了,发现这个端口是本地服务对外提供的dubbo服务的端口号,而我部署的2台tomcat里面部署的应用是一样的,那么就存在这个问题,

本地机器对外提供20883作为dubbo服务端口,而启动了2台,那么就会将20883绑定2次,当然第一次没问题,第二次的时候发现本地端口

20883被占用,其实dubbo这个端口既然是本地分配出来对外提供的,别人也不需要知道端口号,所以我直接修改2台应用中dubbo的端口号,

分配不同的端口不就行了。

 

重新分配之后再次启动,ok没问题了。

######################################另一种解决方式##################################

根据端口找进程号
netstat -anlp | grep 8701
根据进程号找启动路径
ll /proc/4525/cwd

######################################另一种解决方式##################################

 

posted on 2017-01-11 09:47  莫大人  阅读(363)  评论(0编辑  收藏  举报

导航