原理就是因为目前mongodb只有副本,分片支持事务。我们就让单机变成单节点副本,同时又是主节点,可以读写
一、修改bin目录下的mongod.cfg
新增配置
replication:
replSetName: rs0
二、重启mongodb服务、初始化(这是windows下的启动命令)
启动
>mongod --dbpath D:\mongodb\data\db --logpath=D:\mongodb\log\mongodb.log --logappend --replSet=rs0
初始化
D:\mongodb\bin>mongo #先进入mongo里
>rs.initiate() #初始化配置
初始化后过一会儿就可以看见当前结点被选举成主节点了
三、创建user用户,并设置登录账号跟密码
其实不创建用户也可以跟springboot集成使用事务了,不过为了安全,最好还是设置安全认证
>use admin #切换数据库
>db.createUser({user: "admin",pwd: "Admin@123",roles: [ { role: "dbAdminAnyDatabase", db: "admin" } ]}) #在admin库创建管理员
四,application.yml配置
spring:
application:
# 应用名称
name: ruoyi-mongodb
profiles:
# 环境配置
active: @profiles.active@
data:
mongodb:
# uri: mongodb://admin:Admin@123@/test?connect=replicaSet&replicaSet=rs0
host: localhost
port: 27017
database: test
username: admin
password: Admin@123
五、配置文件,注入bean
因为一个服务一般可能同时连接mysql和mongodb,所以需要注入两个bean,默认是mysql的
注意:一个方法中不能既操作mysql又操作mongodb,因为事务不支持
@Configuration
public class TransactionConfig {
@Bean(name = "mybatisTransactionManager")
@Primary //事务默认使用mysql数据库
public DataSourceTransactionManager testTransactionManager(@Qualifier("dataSource") DataSource dataSource) {
return new DataSourceTransactionManager(dataSource);
}
@Bean(name = "mongoTransactionManager")
public MongoTransactionManager transactionManager(MongoDatabaseFactory factory){
return new MongoTransactionManager(factory);
}
}
六、使用办法
涉及mongodb操作时,添加@Transactional(value = "mongoTransactionManager")注解
涉及mysql的直接用@Transactional就可以了