其他分享
首页 > 其他分享> > Spring @Transactional,具有跨多个数据源的事务

Spring @Transactional,具有跨多个数据源的事务

作者:互联网

我必须更新两个数据源作为一个事务的一部分.那是 –

>我在DB1中做了更新.
>然后,我在DB2中进行另一次更新.

如果DB2中的更新失败,我想回滚DB1和DB2以进行回滚.这可以使用@Transactional完成吗?

这是一个示例代码 –

@Transactional(value="db01TransactionManager")
public void updateDb01() {
    Entity01 entity01 = repository01.findOne(1234);
    entity01.setName("Name");
    repository01.save(entity01);

    //Calling method to update DB02
    updateDb02();
}

@Transactional(value="db02TransactionManager")
public void updateDb02() {
    Entity02 entity02 = repository02.findOne(1234);
    entity02.setName("Name");
    repository02.save(entity02);

    //Added this to force a roll back for testing
    TransactionAspectSupport.currentTransactionStatus().setRollbackOnly();
}

我的问题是,updateDb02中的setRollbackOnly()仅回滚Db01事务.

解决方法:

我使用ChainedTransactionManager – http://docs.spring.io/spring-data/commons/docs/1.6.2.RELEASE/api/org/springframework/data/transaction/ChainedTransactionManager.html解决了这个问题

Spring Boot配置:

    @Bean(name = "chainedTransactionManager")
    public ChainedTransactionManager transactionManager(@Qualifier("primaryDs") PlatformTransactionManager ds1,
                                                    @Qualifier("secondaryDs") PlatformTransactionManager ds2) {
         return new ChainedTransactionManager(ds1, ds2);
    }

然后你可以按如下方式使用它:

@Transactional(value="chainedTransactionManager")
public void updateDb01() {
    Entity01 entity01 = repository01.findOne(1234);
    entity01.setName("Name");
    repository01.save(entity01);

    //Calling method to update DB02
    updateDb02();
}

public void updateDb02() {
    Entity02 entity02 = repository02.findOne(1234);
    entity02.setName("Name");
    repository02.save(entity02);

    //Added this to force a roll back for testing
    TransactionAspectSupport.currentTransactionStatus().setRollbackOnly();
}

标签:spring,spring-data-jpa,hibernate,transactions,transactionmanager
来源: https://codeday.me/bug/20191005/1854922.html