java

关注公众号 jb51net

关闭
首页 > 软件编程 > java > @PostConstruct注解导致程序无法启动

解决@PostConstruct注解导致的程序无法启动(@PostConstruct的执行)

作者:是菜菜的小严惜哎

这篇文章主要介绍了解决@PostConstruct注解导致的程序无法启动(@PostConstruct的执行)问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

楼主遇到一个问题,问题大概是这样的

问题

1、业务原因,需要程序初始化启动后自动执行一个程序,这个程序处在一个死循环内,不会结束,保持自动执行

2、程序启动后,其他所有接口无法调用

处理及结果

然后我开始排查啊,排查啊

我先尝试重启服务,重新清空IDE的缓存,重启电脑,换环境执行,结果都不行

然后我在每个方法都打了断点,开始执行,这个时候问题开始露头

我发现它走了@PostConstruct注解的方法,但是我这个方法是个死循环,不会结束的!!!

我大胆猜测,是否是因为@PostConstruct注解的方法未结束,导致的无法执行

于是我写了一个测试工程,进行测试,结果复现了这个问题!!!!!!

我查阅了一下资料,大概明白了问题所在:

springboot启动过程

springboot的bean加载的过程是这样的,程序启动时,springboot会把标记为bean的类或者接口自动进行全局的单例实例化,如果用户指定标记了初始化的顺序,springboot则会按照用户指定的顺序进行初始化,否则就会按照默认的顺序进行初始化,在这个过程中,如果一个bean所在的类或者接口存在@PostConstruct注解,springboot就会在执行完这个bean的构造方法之后执行标记有@PostConstruct注解的方法,然后实例化下一个bean

如果说,带有@PostConstruct注解的方法执行时间很长,那就会影响springboot对bean的实例化时间,进而就会间接影响到程序的初始化启动,如果springboot不初始化完bean,是不会打开端口提供服务的,所以在@PostConstruct注解的方法执行完之前,应用不可访问

所以说,对于轻量级的逻辑,可以放在@PostConstruct注解的方法里,非常耗时的逻辑,可以考虑使用多线程处理,也可以放弃@PostConstruct注解,改用CommandLineRunner和ApplicationRunner 

总结

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

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