在工作中碰到的一个有趣的小BUG,很有意思,涉及到springboot的自动注入知识。
新增一个功能,需要调用A服务中的bean,启动服失败。报错信息是:Error creating bean with name 'authenticationManagerBean': Requested bean is currently in creation: Is there an unresolvable circular reference?
首先分析报错的日志,翻译过来很明显是提示我们:出现循环问题,可能是A和B互相调用了,又或者是对同一个服务的调用造成阻塞,anyway,出现的原因可以找到问题点,那就是bean出现循环引用了。
发现问题解决问题:
我想原因可能是这样:在新增C服务之前,项目中的 A服务中的bean就已经注入了B服务中,现在新增的C服务也要注入A服务中的bean,在启动项目的时候,B服务已经启动,再来启动C服务,就会报错。
解决办法:
spring中的@Lazy注解
添加@Lazy注解
@Lazy注解主要是用于减少springIOC容器启动的加载时间。
总结:
这个问题耗费一天时间,主要原因其实是对spring的底层机制和相关注解不熟悉的原因,在使用注解的时候,不但要能解决问题,还要知道为什么可以解决问题,同时做好记录,以便提醒自己下次碰到同样问题如何解决。