关于动态切换数据源的问题

讨论 未结 10 52
7911364440
7911364440 会员 2022年9月22日 05:57 发表
<p>目前使用的是 AbstractRoutingDataSource+AOP 动态切换数据源,现在有个需求要在一个请求中分别对 A 库和 B 库新增各新增一条数据。</p> <p>伪代码如下:</p> <pre><code class="language-java"> public class FooController { @PostMapping(value = "/foo") public void foo() { // AOP 会拦截这两个 service 中的方法,然后切换数据源 fooService.save(); // 在 A 库插入数据,这里是正常的 barService.save(); // 在 B 库插入数据,这里切换不了数据源,使用的还是 A 数据源 } } </code></pre> <p><strong>问题是只有第一个方法切换数据源有效,第二个方法切换不了数据源。</strong><br> <strong>应该是第二个方法切换数据源之后,没有触发下面这段方法,想问下有没有其它解决方案?</strong></p> <pre><code class="language-java"> public class DynamicDataSource extends AbstractRoutingDataSource { @Override protected Object determineCurrentLookupKey() { return DynamicDataSourceHolder.getKey(); } } </code></pre>
收藏(0)  分享
相关标签: 灌水交流
注意:本文归作者所有,未经作者允许,不得转载
10个回复
  • nekolr
    2022年9月22日 06:56
    建议贴一下 aop 的相关代码
    0 0
  • wolfie
    2022年9月22日 06:56
    注掉 fooService 看看,能不能走 AOP 。
    0 0
  • wolfie
    2022年9月22日 08:27
    贴部分代码吧。 在看看有没有涉及到 异步 相关的东西。
    0 0
  • cheng6563
    2022年9月22日 08:27
    第二个方法必须要启动新事物,不然事务管理器会保持连接
    0 0
  • 7911364440
    2022年9月22日 09:30
    @ 在两个 service 都加上了 @(propagation = Propagation.REQUIRES_NEW) 也不行
    0 0
  • MrZYB
    2022年9月22日 09:30
    切换数据源写个 setDataSource 方法,在调用第 2 个 service.save()时手动切换数据源。
    0 0
  • czn6mx
    2022年9月22日 11:27
    AOP after 清掉 ThreadLocal dataSourceKey
    0 0