最近在搭建SpringBoot项目时遇到打war包部署外部Tomcat,war包能解压,能运行,不报任何错误,但是不能访问tomcat也不能访问项目!本人也是第一次用Netty框架,排查问题和解决过程走了很多弯路,特此将这次过程记录下来,方便有需要的朋友!
项目环境:SpringBoot2.0.1+Netty+mysql+mybatis
编译器:IDEA
排查过程(弯路)
(1)、由于是第一次使用IDEA,以为是版本有些高,换了版本;换版本后排除了这种可能性
(2)、怀疑是公司的网络问题(公司对外网做了限制),打包时未能将相应jar加进war包;经排查排除这种可能性
(3)、怀疑本地仓库出了问题,删除所有拉依赖;排除这种可能性
(4)、怀疑springBoot版本或者是netty版本;经测试排除这种可能性
(5)、这下我都开始怀疑阿里云镜像了,这个没有经过测试;
最后的希望
(6)最终我决定一步一步来排查问题,新建项目只写了helloeword做测试,打包发布竟然测试成功,能访问tomcat,排除1~5所有的弯路,就这样一步一步最终将问题锁定在Netty上,果然项目中引用了Netty打包发布后不能访问Tomcat;
就这样这个罪魁祸首的根源找了出来,接下来就查找问题原因,经过查资料终于找到了问题,如下所示:
服务端绑定端口后异步监听,等待客户端连接,而这个过程线程会变为wait状态,
//绑定端口,开始接收进来的连接
ChannelFuture future = bootstrap.bind().sync();
解决思路:开辟一个新的线程专门用来监听客户端等待客户端,
直接上码
/**
* @ description 解决项目打war包发布在tomcat,端口被占用问题
* 解决思路:给NettyServer分配一个独立的线程用于加载
*/
@Component
public class NettyServerListener implements ApplicationListener<ContextRefreshedEvent> {
private static final Logger logger = LoggerFactory.getLogger(NettyServerListener.class);
/**
* 当一个applicationContext被初始化或被刷新时触发
* @param event
*/
@Override
public void onApplicationEvent(ContextRefreshedEvent event) {
if(event.getApplicationContext().getParent() == null){
logger.info("NettyServer Start Success");
//自己的NettyServer
NettyServer nettyServer=new NettyServer();
new Thread(nettyServer).start();
}
}
}
最后打包发布访问成功!
关于ApplicationListener<ContextRefreshedEvent>的解释,网上有很多的解释,另行查询!
文章中如果有什么不对的地方欢迎朋友指出,共同探讨,一起进步!