MongoDB 部署副本集 + 代码中开启事务

首先,指定副本名称:

vim /etc/mongod.conf

replication:
 replSetName: shard1

在replication里面加入副本名称,多个相同副本,应该使用同样的名称

如果要修改mongodb占用的内存,可以这样设置:

storage:
  wiredTiger:
    engineConfig:
      cacheSizeGB: 1

进入mongo客户端:

mongosh 127.0.0.1:27017

复制代码
rs.initiate({
   _id:"shard1",
   "members":[
     {
        _id:0,
        "host":"192.168.11.137:27017"
     },
     {
        _id:1,
        "host":"192.168.11.138:27017"
     },
     {
        _id:2,
        "host":"192.168.11.139:27017"
     }]  
})
复制代码

 rs.status() 可以看到当前状态

db.isMaster() 查看谁成为了master

用MongoClient连接这几个副本集:

 var client = new MongoClient("mongodb://192.168.11.137:27017,192.168.11.138:27017,192.168.11.139:27017");

 用了副本集,就可以使用事务了:

复制代码
           var client = new MongoClient("mongodb://192.168.11.137:27017,192.168.11.138:27017,192.168.11.139:27017");
            var session = client.StartSession();
            session.StartTransaction();


            var database = client.GetDatabase("MyTestDB");
            var collection = database.GetCollection<UserInfo>("UserInfo");
            collection.InsertOne( session, new UserInfo
            {
                Name = "Jack",
                CreateTime = DateTime.Now,
            });

            session.CommitTransaction();
复制代码

 

posted @   IWing  阅读(278)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 【杭电多校比赛记录】2025“钉耙编程”中国大学生算法设计春季联赛(1)
点击右上角即可分享
微信分享提示