当前位置: 首页 > news >正文

【赵渝强老师】MongoDB文档级别的并发控制

1

MongoDB在执行写操作时,WiredTiger存储引擎会在文档级别进行并发控制。换句话说在同一时间点上,多个写操作能够修改同一个集合中的不同文档;而当多个写操作修改同一个文档时,必须以序列化方式执行。这意味着如果当前文档正在被修改,其他写操作必须等待该文档上的写操作完成之后才能进行修改。对于大部分的文档读写操作,WiredTiger引擎使用的都是乐观锁;而在数据库和集合级别,WiredTiger使用的是意向锁。当WiredTiger存储引擎探测到两个操作之间发生了冲突,将会产生一个写冲突并将会重新执行操作。

image.png
点击这里查看视频讲解:【赵渝强老师】MongoDB文档级别的并发控制

在了解到了MongoDB的并发控制机制以后,下面通过一个示例来演示如何监控MongoDB锁的信息。

(1)切换到scott数据库中。

test@nosql11 1> use scott

(2)通过一个循环向MongoDB的集合中插入100百万条文档:

scott@nosql11 3> for(var i=1; i<=1000000;i++){db.test4.insert({"_id":i,"action":"write simulations","iteration no:":i});
}

(3)使用mongotop监控MongoDB读写操作的统计信息。

mongotop# 输出的信息如下:
2022-04-04T15:48:58+08:00
ns    					total		read		write  
scott.test4				114ms		0ms			114ms  
admin.system.version	0ms			0ms			0ms  
config.system.sessions	0ms			0ms			0ms  
config.transactions		0ms			0ms			0ms  
local.system.replset	0ms			0ms			0ms 

(4)使用db.serverStatus监控锁的信息。

scott@nosql11 6> db.serverStatus().locks# 输出的信息如下:
......"Database" : {"acquireCount" : {"r" : NumberLong(10),"w" : NumberLong(119862),"R" : NumberLong(1),"W" : NumberLong(1)}},"Collection" : {"acquireCount" : {"r" : NumberLong(13),"w" : NumberLong(119860),"W" : NumberLong(2)}},
......

提示:从锁的信息可以看出,此时在数据库级别和集合级别产生了大量的写锁信息。

http://www.jsqmd.com/news/104948/

相关文章:

  • 2025年评价高的大型均质机行业内知名厂家排行榜 - 品牌宣传支持者
  • 2025年热门的丝瓜抹布厂家最新用户好评榜 - 品牌宣传支持者
  • 《35岁及以上码农破局指南方法论及落地方案》
  • HLS.js快速上手:5个步骤构建专业级浏览器视频播放器
  • h5网页实现人脸识别(vue3+ts)
  • 5分钟快速上手:打造专属个性化鼠标指针的完整指南
  • RabbitMQ发布订阅模式同一消费者多个实例如何防止重复消费?
  • React Big Calendar终极指南:从零构建企业级日历应用的完整教程
  • 2025年质量好的植物纤维百洁布厂家综合实力榜(2025) - 品牌宣传支持者
  • 50、INN新闻服务器与新闻阅读器配置指南
  • 基于Vue.js和SpringBoot的新能源汽车充电站管理系统外文翻译
  • FlashDB / Easyflash触发GC导致系统卡死的解决方法分享
  • llm范式(ReAct、Plan-and-Execute)
  • 终极AMD 780M APU性能优化指南:释放GPU全部潜力
  • 51、Linux网络工具配置与网络连接搭建指南
  • 企业级PDF集成方案:如何选择高性能.NET PDF组件
  • 安达发|APS计划排产排程排单软件实现医疗器械的“零缺陷排程”!穿透表面看本质2025-12-17 11:50
  • 3分钟快速上手Venera:跨平台漫画阅读神器完整指南
  • 【赵渝强老师】MongoDB的Journal日志
  • Android为何引入Java而不完全使用Java所有特性
  • WebPShop:Photoshop终极WebP解决方案,5分钟快速上手
  • 【linux内核】nfs协议版本
  • 思源宋体体积优化指南:从20MB到8MB的实战方法
  • 2025年热门的装配式预制钢结构厂家选购全指南(完整版) - 品牌宣传支持者
  • 浪女回头金不换,华夏女子好巾帼
  • 如何用Excel快速构建智能知识图谱?SmartKG完整指南
  • 基于vue.js和springboot的学生信息可视化系统
  • 系统 “清洁 + 体检” 神器!这款卸载工具,强制卸毒瘤
  • 如何快速配置NewGAN-Manager:面向新手的完整教程
  • 如何快速解决Edge-TTS语音合成地区访问限制问题