开发错误总结---@PostConstruct注解导致的程序无法启动(@PostConstruct的执行)

目录

问题

处理及结果

springboot启动过程


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

问题

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 

  • 2
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值