多数据源动态加载事务控制
源码下载地址:https://github.com/qingqiangqiang/dynamic_datasource.git
根据spring boot官方文档描述,如果spring boot检测到了jta环境,会自动进行配置,故此处不需要进行事务配置
官方地址:http://docs.spring.io/spring-boot/docs/current/reference/html/boot-features-jta.html
可以看到Atomikos会分别管理在两个数据源上。
但这种事务管理多数据源,如果A数据源操作成功,B数据源操作失败,A数据源不会回滚。如下:
我们再看代码执行结果和数据库结果:
可见这种事务管理,对于多数据原来说,异常回滚的处理,并不能正确处理,还是需要使用托管事务管理器。
@Bean
public DataSourceTransactionManager transactionManager(@Qualifier("dynamicDS1") DynamicDataSource dynamicDS1) {
DataSourceTransactionManager transactionManager = new DataSourceTransactionManager();
transactionManager.setDataSource(dynamicDS1);
return transactionManager;
}
可以看到,托管后的事务会管理在动态数据源的bean上,这样就会有效控制多数据源的事务。再次执行test,数据库不会再有新数据生成。