java.net.BindException: Address already in use at sun.nio.ch.Net.bind0(Native Method) at sun.nio.ch.Net.bind(Net.java:444) at sun.nio.ch.Net.bind(Net.java:436) at sun.nio.ch.ServerSocketChannelImpl.bind(ServerSocketChannelImpl.java:214) at sun.nio.ch.ServerSocketAdaptor.bind(ServerSocketAdaptor.java:74)
原因是热部署时候,tomcat关闭时候端口未被释放
如何释放端口呢?
先查看端口被谁在占用,执行命令 ,比如我的netty监听端口为14141
netstat -tunlp|grep 14141
查到结果
tcp 0 0 0.0.0.0:14141 0.0.0.0:* LISTEN 3529/java
可以看到端口正在被3529的进程占用
调用tomcat的shutdown.sh根本不能释放端口
继续输入命令干掉进程
kill -9 3529
结束掉进程之后 去tomcat/webapps目录下面 把要热部署的项目全部删掉(如有需要请备份)
启动tomcat 执行startup.sh 因为项目被删了 再执行netstat -tunlp|grep 14141时候可以看到端口已被释放
回到eclipse 执行
tomcat:deploy
记住是deploy不是redeploy 因为服务器的项目已经被干掉了 所以要用deploy
执行成功后 发布成功 netty监听端口完美解决