• 首页 首页 icon
  • 工具库 工具库 icon
    • IP查询 IP查询 icon
  • 内容库 内容库 icon
    • 快讯库 快讯库 icon
    • 精品库 精品库 icon
    • 问答库 问答库 icon
  • 更多 更多 icon
    • 服务条款 服务条款 icon

mongoDB5以上实现单机事务

武飞扬头像
qq_41369135
帮助1

原理就是因为目前mongodb只有副本,分片支持事务。我们就让单机变成单节点副本,同时又是主节点,可以读写

一、修改bin目录下的mongod.cfg

学新通

新增配置

  1.  
    replication:
  2.  
    replSetName: rs0

二、重启mongodb服务、初始化(这是windows下的启动命令)

启动

>mongod --dbpath D:\mongodb\data\db --logpath=D:\mongodb\log\mongodb.log --logappend  --replSet=rs0

初始化

  1.  
    D:\mongodb\bin>mongo #先进入mongo里
  2.  
     
  3.  
    >rs.initiate() #初始化配置

初始化后过一会儿就可以看见当前结点被选举成主节点了

学新通

三、创建user用户,并设置登录账号跟密码

其实不创建用户也可以跟springboot集成使用事务了,不过为了安全,最好还是设置安全认证

  1.  
    >use admin #切换数据库
  2.  
     
  3.  
    >db.createUser({user: "admin",pwd: "Admin@123",roles: [ { role: "dbAdminAnyDatabase", db: "admin" } ]}) #在admin库创建管理员

四,application.yml配置

  1.  
    spring:
  2.  
    application:
  3.  
    # 应用名称
  4.  
    name: ruoyi-mongodb
  5.  
    profiles:
  6.  
    # 环境配置
  7.  
    active: @profiles.active@
  8.  
    data:
  9.  
    mongodb:
  10.  
    # uri: mongodb://admin:Admin@123@/test?connect=replicaSet&replicaSet=rs0
  11.  
    host: localhost
  12.  
    port: 27017
  13.  
    database: test
  14.  
    username: admin
  15.  
    password: Admin@123
学新通

五、配置文件,注入bean

因为一个服务一般可能同时连接mysql和mongodb,所以需要注入两个bean,默认是mysql的

注意:一个方法中不能既操作mysql又操作mongodb,因为事务不支持

  1.  
    @Configuration
  2.  
    public class TransactionConfig {
  3.  
     
  4.  
    @Bean(name = "mybatisTransactionManager")
  5.  
    @Primary //事务默认使用mysql数据库
  6.  
    public DataSourceTransactionManager testTransactionManager(@Qualifier("dataSource") DataSource dataSource) {
  7.  
    return new DataSourceTransactionManager(dataSource);
  8.  
    }
  9.  
     
  10.  
    @Bean(name = "mongoTransactionManager")
  11.  
    public MongoTransactionManager transactionManager(MongoDatabaseFactory factory){
  12.  
    return new MongoTransactionManager(factory);
  13.  
    }
  14.  
     
  15.  
    }
学新通

六、使用办法

涉及mongodb操作时,添加@Transactional(value = "mongoTransactionManager")注解

涉及mysql的直接用@Transactional就可以了

这篇好文章是转载于:学新通技术网

  • 版权申明: 本站部分内容来自互联网,仅供学习及演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,请提供相关证据及您的身份证明,我们将在收到邮件后48小时内删除。
  • 本站站名: 学新通技术网
  • 本文地址: /boutique/detail/tanhgkfkgb
系列文章
更多 icon
同类精品
更多 icon
继续加载