当前位置:首页 > AI技术 > 正文内容

理开发怎么为MongoDB事务调优将读操作尽量移事务外面执行|Duuu笔记

admin2个月前 (04-04)AI技术50

前端进阶技巧:本文深入解析

事务内读操作拖慢MongoDB性能,因其强制快照读导致锁范围扩大、快照开销上升、WiredTiger缓存压力增大;仅两类读必须留在事务内:依赖一致性的读和用于写冲突判断的读。

为什么事务里做读操作会拖慢 MongoDB 性能

MongoDB 事务本质是加锁 + 日志 + 一致性快照,只要读操作在

session.startTransaction()

session.commitTransaction()

之间,就会强制走事务快照读(snapshot read),哪怕你只是

collection.findOne()

查一条不相关的文档。这会导致:锁范围扩大、快照维护开销上升、WiredTiger cache 压力变大——尤其在高并发写场景下,读操作反而成了事务瓶颈。

哪些读操作必须留在事务内

只有两类读操作不能移出去:

依赖事务一致性的读

(比如“先查余额,再扣款”)和

用于写冲突判断的读

(如基于旧值做条件更新)。其他所有读都该挪走。常见误留场景包括:

collection.countDocuments()

统计用于日志或监控(与业务逻辑无关)

collection.find().toArray()

加载配置或字典数据(这些数据本身不参与事务逻辑)

为日志拼接用户昵称而查

users.findOne()

(昵称不参与扣款/状态变更)

怎么安全地把读移到事务外

核心原则是:**读操作必须在事务开始前完成,且结果传入事务函数作为不可变输入**。注意三点:

不要在事务内调用异步读(如

await collection.findOne()

),哪怕它看起来“只是读”

如果读结果用于写条件(例如

updateOne({ _id, status: "pending" })

),确保该读发生在事务快照中——此时必须保留在事务内,不能简单“提前读”

对多集合关联读,若只有一部分参与事务逻辑,拆成“事务外预读 + 事务内局部验证”

示例(Node.js):

独响

一个轻笔记+角色扮演的app

下载

// ✅ 正确:配置类读提前完成

const config = await configs.findOne({ key: "fee_rate" });

const user = await users.findOne({ _id: userId }); // 用户基础信息,不参与状态变更

// 事务只做原子写

await session.withTransaction(async () => {

const order = await orders.findOne({ _id: orderId }, { session });

if (order.status !== "created") throw new Error("invalid status");

await orders.updateOne(

{ _id: orderId },

{ $set: { status: "paid", fee: config.rate * order.amount } },

{ session }

);

});

容易被忽略的隐式读操作

有些读不是显式

find

,但一样进事务快照:

collection.bulkWrite()

中的

upsert: true

会隐式执行一次查询判断是否存在

collection.replaceOne()

默认带

upsert: false

,但如果设为

true

,就等价于“读+写”

使用

$expr

的更新条件(如

{ $gt: ["$updatedAt", "$createdAt"] }

)需要读取文档字段,也走快照

这类操作一旦出现在事务里,又没实际业务必要,就是性能黑洞。检查

mongod

日志里的

transaction

段落,留意

numReads

字段是否异常高。

事务不是万能隔离罩,它只解决“写-写冲突”和有限的“读-写一致性”,别把它当读操作的保险柜。

相关文章

【大模型应用开发

二、大模型的泛化与微调 模型的泛化能力:是指一个模型在面对新的、未见过的数据时,能够正确理解和预测这些数据的能力。在机器学习和人工智能领域,模型的泛化能力是评估模型性能的重要指标之一。...

一文讲清神经网络、BP神经网络、深度学习的关系

人工神经网络中的顶级代表。往往说《神经网络》就是指《BP神经网络》。 大家研究着各种神经网络,研究得不亦乐乎, 来了两个家伙Romelhart 和Mcclelland,...

从入门到精通:前端开发之骡子快跑支持热点借势吗 骡子快跑节日营销文案生成|Duuu笔记

骡子快跑平台提供五步节日营销文案生成路径:一、调用内置32个节日模板库;二、输入热点事件触发动态生成;三、绑定自有素材库实现个性化延展;四、多角色视角协同输出;五、接入微信生态直发并校验合规性。 ☞...

深入理解AI:WorkBuddy 怎么做组织架构图 WorkBuddy 组织架构图生成教程【实战】完全指南|Duuu笔记

WorkBuddy可通过四种方式生成组织架构图:一、用自然语言指令触发AI自动解析并渲染Mermaid图表;二、上传Excel结构化数据映射字段后批量构建动态树状图;三、启用OpenClaw技能包对接...

AI实战详解:Perplexity 怎么做市场调研 Perplexity 市场分析实操教程【商业】最佳实践|Duuu笔记

掌握Perplexity AI市场调研需五步:一、结构化提问嵌入地域/时间/主体/指标四要素;二、限定PDF等原始信源提升可信度;三、分步提问生成制表符分隔文本以自动导入Excel;四、启用Pro S...

深入理解前端开发:Minimax视频生成黑科技:复杂动作模拟完全指南|Duuu笔记

为精准模拟复杂动作,需采用分帧提示词构建、骨骼关键点引导注入和多阶段动作蒸馏三法:一、将动作拆解为带空间姿态的关键帧序列并加物理约束;二、注入2D/3D关键点坐标锚定关节位置;三、通过粗生成→特征提取...

发表评论

访客

看不清,换一张

◎欢迎参与讨论,请在这里发表您的看法和观点。