Springboot MongoDb Mysql 多数据源 事务配置

本文介绍了如何在Springboot项目中集成MongoDb并实现与Mysql的多数据源事务配置。在MongoDb支持事务的前提下,通过AOP声明式事务和注解式事务管理,分别配置了jdbcTransactionManager和MongoTransactionManager。注意,MongoDb的事务仅在集群模式下有效。由于Spring的限制,一个方法内无法同时对多个数据库进行事务操作,但可以通过自定义注解来实现跨数据库的事务管理。
  1. 软件版本:
    MongoDb:
    使用Docker进行部署
root@119ce58d3c1f:/# mongo
MongoDB shell version v4.4.5
connecting to: mongodb://127.0.0.1:27017/?compressors=disabled&gssapiServiceName=mongodb
Implicit session: session {
   
    "id" : UUID("c278fd96-dbe5-44bc-a608-3a0bb3307b3d") }
MongoDB server version: 4.4.5
Springboot版本:
<parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.4.5</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
  1. 场景:
    由于项目部分模块更适合使用mongoDb,于是尝试引入MongoDb,原项目本来是Springboot+MybatisPlus+Mysql的架构。
    由于MongoDb在现有版本已经支持事务
    于是想进行事务配置,实现Mysql和MongoDb混合事务
  2. 事务启用配置:
    由于项目本身还有用到Mysql,用的是AOP声明式事务配置,此次添加MongoDb只要用注解式事务即可。
    在配置时要注意,此时会存在两个TransactionManager,一个是jdbcTransactionManager还有一个是
    MongoTransactionManager。
    为了不冲突,需要配置各自的名称。(如果没有多数据源,则无需此步)
	@Bean(name = "mongoTransactionManager")
    MongoTransactionManager mongoTransactionManager(MongoDatabaseFactory dbFactory){
   
   
        return new MongoTransactionManager(dbFactory);
    }
	@Bean(name = "jdbcTransactionManager")
    @Primary
    JdbcTransactionManager jdbcTransactionManager(DataSource dataSource){
   
   
        return new JdbcTransactionManager(dataSource);
    }

完整配置如下

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值