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();
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 【杭电多校比赛记录】2025“钉耙编程”中国大学生算法设计春季联赛(1)