SpringBoot集成ShardingSphere-JDBC、dynamic-datasource-spring-boot-starter,切换数据源后分库分表规则无效

SpringBoot集成ShardingSphere-JDBC、dynamic-datasource-spring-boot-starter,切换数据源后分库分表规则无效

问题:添加@DS,规则失效。切换数据源是成功的,但规则没有生效

原因:因方法添加@Transactional注解导致

数据源是否成功:

// 在添加@DS的方法内部执行如下代码
// 结果为执行本次代码时,持有的数据源名。注意这个只是表明多数据源切换是否成功,不代表拿这个数据源真正执行后续方法
String dataSourceName = DynamicDataSourceContextHolder.peek();

理解:

  • 在方法1中调用方法2,且方法1被@Transactional修饰,如果方法2使用@DS切换数据源将会失效。原因:@Transactional修饰方法时,Spring会维护一个connection对象,保证在事务下整个线程后续拿到的是同一个connection对象,故执行到内部方法时,切换了数据源,Spring在做事务提交时拿到的也是维护的connection对象,并不会拿到切换数据源后的connection对象。
  • @Transactional@DS可以连用,因为会先触发切换数据源,后开启事务。维护的connection对象也是切换数据源之后的connection对象

解决方案:

1.检查添加@DS所在的方法 是否 为 本次测试功能的直接业务方法,即Contrller代码中直接调用 添加 @DS的所在方法

2.如果不是直接业务方法,则判断外层业务方法是否添加@Transactional。如果添加则去除。或者在外层业务方法上添加@DS

强烈建议:不要在一个事务中切换数据源。切换数据源会导致事务失效

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值