- 软件版本:
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>
- 场景:
由于项目部分模块更适合使用mongoDb,于是尝试引入MongoDb,原项目本来是Springboot+MybatisPlus+Mysql的架构。
由于MongoDb在现有版本已经支持事务
于是想进行事务配置,实现Mysql和MongoDb混合事务 - 事务启用配置:
由于项目本身还有用到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);
}
完整配置如下

本文介绍了如何在Springboot项目中集成MongoDb并实现与Mysql的多数据源事务配置。在MongoDb支持事务的前提下,通过AOP声明式事务和注解式事务管理,分别配置了jdbcTransactionManager和MongoTransactionManager。注意,MongoDb的事务仅在集群模式下有效。由于Spring的限制,一个方法内无法同时对多个数据库进行事务操作,但可以通过自定义注解来实现跨数据库的事务管理。

1543

被折叠的 条评论
为什么被折叠?



