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

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

在这里插入图片描述

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

视频讲解如下

【赵渝强老师】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.kler.cn/a/466603.html

相关文章:

  • CSS 之 position 定位属性详解
  • Docker 容器内部如何访问本机的服务
  • SQL—Group_Concat函数用法详解
  • 数据挖掘——朴素贝叶斯分类
  • Kotlin 数据类与密封类
  • 面试题解,JVM中的“类加载”剖析
  • vue 虚拟滚动 vue-virtual-scroller RecycleScroller
  • logback日志文件多环境配置路径
  • Linux下读取Windows下保存的文件,报错信息中出现“^M“时如何解决?【由于Windows和Linux的换行方式不同造成的-提供两种转换方式】
  • React18路由和Vue3路由进行对比
  • [2024] 如何以 5 种可行的方式在Android中打开 HEIC 文件?
  • aardio —— 虚表 —— 模拟属性框
  • Edge Scdn的应用场景有哪些?
  • VScode SSH 错误:Got bad result from install script 解決
  • CG顶会论文阅读|《科技论文写作》硕士课程报告
  • FreeSWITCH dialplan/default.xml 之释疑
  • 如何删除 Android 设备上的应用程序 | 3种高效方法
  • Springcloud项目-前后端联调(一)
  • 代码随想录算法训练营day21
  • Spring线程池优雅关闭
  • YOLOv8/YOLOv11改进 添加CBAM、GAM、SimAM、EMA、CAA、ECA、CA等多种注意力机制
  • GWAS数据和软件下载
  • JeeSite 快速开发平台:全能企业级快速开发解决方案|GitCode 光引计划征文展示
  • 【深度学习进阶】基于CNN的猫狗图片分类项目
  • pycharm 命令行下的链接,不自动形成链接和定位了。
  • 深入解析-正则表达式