SpringBoot多数据源启动出现循环依赖问题
在使用SpringBoot的项目中,如果是有使用多数据源,可能会存在启动时数据源循环依赖的报错,是因为使用了多数据源注入,和DataSourceAutoConfiguration数据源自动配置的DataSourceInitializerInvoker互相产生循环依赖导致。
这种错误可能会一些环境才会报错,是因为当一些依赖的bean先创建的时候,就会因为注入需要DataSource,因此进行创建动态数据源DynamicDataSource(即自定义的AbstractRoutingDataSource类的实现类),创建DynamicDataSource前会先创建依赖的masterDataSource,masterDataSource创建好后会触发DataSourceInitializerPostProcessor的postProcessAfterInitialization方法,导致需要创建DataSourceInitializerInvoker,而DataSourceInitializerInvoker又需要依赖DynamicDataSource,多个地方都需要创建DynamicDataSource,从而出现循环依赖问题。有些环境不出现是因为跟打包和环境加载的类顺序有关,如果依赖的bean在DynamicDataSource后创建就不会产生循环依赖。
最终解决方案:在启动的时候排除掉 DataSourceAutoConfiguration 自动配置。
附加:如果确实是需要使用DataSourceInitializerInvoker初始化一些数据库脚本,则可以对一些出现问题的依赖类进行加上@Lazy懒加载来处理。