多数据源单服务写入, 分布式事务实现
使用随机数控制产生异常
注: 网上很多都是只有多数据源配置,实际不能控制事务统一回滚,
单服务场景下如果多个数据源只有一个写,剩下都是读, 则不需要分布式事务
为减少篇幅,详细代码在代码仓库,可自行参考
版本springboot 2.1.7.RELEASE
配置引入增加配置类org.springframework.boot spring-boot-starter-data-jpamysql mysql-connector-javaorg.springframework.boot spring-boot-starter-jta-atomikos
AtomikosJtaPlatform
JPAAtomikosTransactionConfig Atomikos事务配置类
PrimaryConfig 主数据源配置
SecondaryConfig 其它数据源配置
数据对象实现User
增加仓储实现需要分别实现primary和secondary, 从而支持多个数据源访问
PrimaryUserRepository
SecondaryUserRepository
实现服务类PrimaryUserService
SecondaryUserService
ExampleService负责统一调用 PrimaryUserService 和 SecondaryUserService,
模拟一个服务同时访问多个服务类(每个服务类引用了不同数据源)
如果其中某个服务抛出异常,则整个事务回滚, @Transactional(rollbackOn =
Exception.class) 是必须的
com.example.springbootatomikos.services.UserServiceTest#testSave
代码github地址
gitee地址



