java

关注公众号 jb51net

关闭
首页 > 软件编程 > java > sprinboot项目启动一半到图形化界面卡住

sprinboot项目启动一半到图形化界面卡住了的解决

作者:懒得得

这篇文章主要介绍了sprinboot项目启动一半到图形化界面卡住了的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

sprinboot项目启动一半到图形化界面卡住 

问题

有一个新项目需要从旧项目摘出去,于是新配了一个环境,结果结果放到测试环境去的时候,他居然卡住了,而且没有任何输出就卡在图形化界面了,生平第一次见。

解决

重新打了很多次的包,还是不行。😟

真是一个bug能占我一天(我要坚强),最后让大佬看了一下,十分钟就解决了。

这里发现的问题是因为日志的配置有问题,之前配置文件就那么几个,也没注意到 logback-spring.xml 配置文件里面有一个环境的配置。

红框为之前的测试环境,绿框为这次新增的环境。 

比如application-test.yml,那么这里配置的就是 name=“test”。

像这种卡住了,一般不会是说数据库连不上,因为连不上就报sql错误了。说什么 启动类加上 注解的,也试过。但是这个一点日志出不来的,肯定是和日志有关系。遇到不会的就要虚心去问。

sprinboot项目启动卡住,无任何异常信息

项目场景

SpringBoot项目启动的时候Console控制台日志打印卡住,无任何异常信息打印

问题描述

之前项目是好的,但是后面经人写了一部分代码之后,项目启动不了,SpringBoot项目启动时直接卡住,日志也不打印,也没有具体的异常信息,某位同事折腾一天。

原因分析

之前我遇到过类似的问题。现在我把我所有的问题分析列在下面:

有可能是改动了pom.xml文件,项目没有彻底更新,导致引入的jar存在版本问题或者根本没有引入进来 

项目是Debug模式启动,然后有一些特殊的断点导致项目启动卡住

项目的目录结构变更,导致某些bean没有被加载到?或者加载了多个相同的bean

某些异常没有被捕获到,同时启动类里面也没有加上全局的try-catch,导致项目卡住

部分代码需要随程序自启,使用@PostConstruct、InitializingBean、ApplicationRunner等方式实现项目初始化时加载,如果有远程连接,而且连接失败或者异常了,没有try-catch,也容易导致启动程序卡死。

解决方案

针对上述列出来的分析,我们可以采用以下解决方案,一步步尝试

如果是pom.xml变更了没生效,我们只需要对pom.xml 重新import即可,另外可以考虑清除idea缓存

如果是debug模式的断点引起的话,去掉所有断点再试试

如果是项目目录结构变更,这个maven clean一下,重新install 即可

如果可以变更启动类的话,建议在开发阶段对启动类的main方法里面的代码加上try-catch,这样启动项目的时候就知道具体异常是什么

如果说分析哪些程序自启的代码导致项目启动卡住的话,我建议查看项目启动快照,具体如下: 

分析当前主线程到底因为什么卡住(waiting),比如我这里是因为数据源配置的有问题导致卡住

最终解决方案:6、如果上述方案都无法解决问题,那么可以查看项目启动日志文件,一般和项目同级目录或者有个log目录存储,里面会记录所有信息/异常信息

例如:这里是我同事的异常:

异常分析:是因为他从另外一个项目copy过来的mapper.xml文件,之前用的是mybatis,现在项目用的ibatis,不识别<where>标签,ibatis只支持<dynamic prepend="where"> 来用

改成ibatis识别的方式即可。  这里注重给大家讲怎么去找到并分析异常。

总结

项目启动卡住了,肯定是有异常原因存在,我们需要的是沉着冷静,一步步找问题所在。另外就是大家在CV代码时,尤其是两个不同的项目的时候,一定要注意细节啊!

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

您可能感兴趣的文章:
阅读全文