mongodb学习--会话模式

本文详细介绍了在Golang中使用mgo包连接MongoDB时的三种会话一致性模式:Strong、Monotonic和Eventual。Strong模式确保读写操作始终一致并反映最新状态;Monotonic模式保持会话内读取的一致性,同时允许部分读负载分配到辅助服务器;Eventual模式提供最少的资源消耗,但顺序性保证最低。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

初次使用mongodb,对很多的东西都不了解,在此做个学习记录
使用的包是mgo

golang连接mongodb会话一致性的三种模式

strong

强一致性模式建立的会话,将始终使用唯一的连接对主服务器进行读写,从而使读写完全一致,使数据保持有序,并始终是最新更新的状态。
分配负载而言,这无疑是没有任何益处的,但这种方式却是读写数据最有保证的。

Monotonic

单调一致性模式读取的数据并不是最新的,但它们会始终看到变化的历史,在同一会话中顺序查询读取的数据将保持一致,并会在接下来的对话中观察到会话中进行的修改。
单调模式通过与任意辅助服务器的唯一连接上进行初始读取而获得的,并且一旦发生首次写入,会话连接就会切换到主服务器;这种管理方式通过分配一些读负载到辅助服务器,同时保有一定的数据保证。

Eventual

最终一致性模式,最快,最节省资源的模式,但是也是对读写数据的顺序性保证最低的一种模式。

参考文档:
https://godoc.org/gopkg.in/mgo.v2#Session.SetMode
一致性区别
https://zhuanlan.zhihu.com/p/67949045

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值