Spring Boot Druid 多数据源 Atomikos 分布式事务缺陷

多数据源动态加载事务控制

源码下载地址: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事务管理自动加载
atomikos事务管理加载在具体数据源上1
atomikos事务管理加载在具体数据源上2
可以看到Atomikos会分别管理在两个数据源上。
但这种事务管理多数据源,如果A数据源操作成功,B数据源操作失败,A数据源不会回滚。如下:
这里写图片描述
我们再看代码执行结果和数据库结果:
这里写图片描述
这里写图片描述

可见这种事务管理,对于多数据原来说,异常回滚的处理,并不能正确处理,还是需要使用托管事务管理器。

    @Bean
    public DataSourceTransactionManager transactionManager(@Qualifier("dynamicDS1") DynamicDataSource dynamicDS1) {
        DataSourceTransactionManager transactionManager = new DataSourceTransactionManager();
        transactionManager.setDataSource(dynamicDS1);
        return transactionManager;
    }

这里写图片描述

这里写图片描述
可以看到,托管后的事务会管理在动态数据源的bean上,这样就会有效控制多数据源的事务。再次执行test,数据库不会再有新数据生成。

猜你喜欢

转载自blog.csdn.net/qq_24228375/article/details/79948157