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

4 篇文章 0 订阅

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

源码下载地址: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,数据库不会再有新数据生成。

参与评论 您还未登录,请先 登录 后发表或查看评论

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

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
©️2022 CSDN 皮肤主题:大白 设计师:CSDN官方博客 返回首页

打赏作者

莫然qq

你的鼓励将是我创作的最大动力

¥2 ¥4 ¥6 ¥10 ¥20
输入1-500的整数
余额支付 (余额:-- )
扫码支付
扫码支付:¥2
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值