关于SpringBoot+Netty打war包部署外部tomcat导致Tomcat不能访问的解决办法

最近在搭建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 {

    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的解释,网上有很多的解释,另行查询!

文章中如果有什么不对的地方欢迎朋友指出,共同探讨,一起进步!

你可能感兴趣的:(框架集成)