首页 > 其他 > 详细

程序端口被占用分析

时间:2017-01-11 10:25:48      阅读:266      评论:0      收藏:0      [点我收藏+]

这几天弄测试环境和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没问题了。

 

程序端口被占用分析

原文:http://www.cnblogs.com/yun965861480/p/6272448.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!