Spring3.0配置多个事务管理器(即操作多个数据源)的方法

Posted zishengY

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Spring3.0配置多个事务管理器(即操作多个数据源)的方法相关的知识,希望对你有一定的参考价值。

大多数项目只需要一个事务管理器。然而,有些项目为了提高效率、或者有多个完全不同又不相干的数据源,最好用多个事务管理器。机智的Spring的Transactional管理已经考虑到了这一点,首先分别定义多个transactional manager,并为qualifier属性指定不同的值;然后在需要使用@Transactional注解的时候指定TransactionManager的qualifier属性值或者直接使用bean名称。配置和代码使用的例子:

 

<tx:annotation-driven/>

<bean id="transactionManager1" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
    <property name="dataSource" ref="datasource1"></property>
    <qualifier value="datasource1Tx"/>
</bean>

<bean id="transactionManager2" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
    <property name="dataSource" ref="datasource2"></property>
    <qualifier value="datasource2Tx"/>
</bean>

使用时,用@Transactional("datasource1Tx")和@Transactional("datasource2Tx"),来区别具体使用某个事务管理器

public class TransactionalService {

    @Transactional("datasource1Tx")
    public void setSomethingInDatasource1() { ... }

    @Transactional("datasource2Tx")
    public void doSomethingInDatasource2() { ... }
}

 

或者,直接使用transactin manager 的bean名字:

@Transactional("transactionManager1")
如果是使用@Transactional(),相当于使用缺省的transaction mananger名字,即:@Transactional("transactionManager")
 

以上是关于Spring3.0配置多个事务管理器(即操作多个数据源)的方法的主要内容,如果未能解决你的问题,请参考以下文章

从零开发短视频电商 缓存Cache实战SimpleCaffeine和Redis多缓存管理器

spring3.0使用annotation完全代替XML

Spring Boot 项目中配置多数据源@Transactional注解失效问题

spring3.0+Atomikos 构建jta的分布式事务

spring事务内如何查询别的数据源

spring3.0+Atomikos 构建jta的分布式事务