解决@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
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。