MongoDB在执行写操作时,WiredTiger存储引擎会在文档级别进行并发控制。换句话说在同一时间点上,多个写操作能够修改同一个集合中的不同文档;而当多个写操作修改同一个文档时,必须以序列化方式执行。这意味着如果当前文档正在被修改,其他写操作必须等待该文档上的写操作完成之后才能进行修改。对于大部分的文档读写操作,WiredTiger引擎使用的都是乐观锁;而在数据库和集合级别,WiredTiger使用的是意向锁。当WiredTiger存储引擎探测到两个操作之间发生了冲突,将会产生一个写冲突并将会重新执行操作。
视频讲解如下 |
---|
【赵渝强老师】MongoDB文档级别的并发控制 |
在了解到了MongoDB的并发控制机制以后,下面通过一个示例来演示如何监控MongoDB锁的信息。
(1)切换到scott数据库中。
test@nosql11 1> use scott
(2)通过一个循环向MongoDB的集合中插入100百万条文档:
scott@nosql11 3> for(