MongoDB中, 文档级别的的写操作是原子性的, 甚至是在对某个文档的操作中修改其多个内嵌的子文档, 也是原子性的.

在一个写操作同时修改多个文档的情况, 对其中单独的某个文档而言是原子的, 但是对整批文档而言并不是原子的, 其他的

操作很可能会交错修改数据. 然而, 可以通过使用$isolated操作符, 隔离某个修改多个文档的写操作.

$isolated 操作符

通过使用$isolated操作符, 多文档写操作一旦开始写第一个文档,就会阻止其他进程交错修改. 这就确保了没有客户端可以看到数据变化, 直到写操作成功或者报错.

$isolated操作符不支持sharded clusters

然而 isolated 写操作无法提供 “all-or-nothing” 原子性的保障. 这意味着写操作出错时, 无法回滚发生错误之前的所有的变化.

注意: $isolated 操作符会导致写操作请求一个集合级别的排它锁, 即使使用了支持文档级别锁的 WiredTiger 存储引擎的情况下也一样. 这意味着, $isolated 操作符会使得 WiredTiger 在操作期间单线程化.

使用$isolated操作符的更新操作的例子, 请参见: $isolated
使用$isolated操作符删除操作的例子, 请参见: Isolate Remove Operations.

类事务语义

单个文档中可以内嵌多个子文档, 所以单文档原子性可以满足多数实际使用需求.对于涉及多文档的写操作序列必须作为一个单独的事务对待的情况,

可以在应用中实现一个two-phase commits 两步提交. 然而, two-phase commits只能提供类似事务的语义. 使用two-phase commits可以

确保数据的一致性(最终结果的一致性), 但是可能会使得应用程序(不小心)读到在two-phase commits或rollback期间产生的中间数据.

关于two-phase commit 和 rollback的更多信息, 请参见: Perform Two Phase Commits

并发控制

并发控制允许多个应用并发执行, 不会导致数据的不一致性或冲突. 方法一是在一个字段上创建一个唯一索引, 使得该字段只能有一个唯一的值. 这样

就避免了插入或更新时带来重复数据. 对于多个字段, 在其上创建唯一索引来强制这些个字段值组合的唯一性. 例子请参见 update() and Unique Index

和 findAndModify() and Unique Index. 另一个方法是为写操作在查询谓词中指定字段所期望的当前值, 具体例子请参见: Update if Current

two-phase commit 模式提供了一个变种, 在查询操作中, 其查询谓词中使用应用程序标识代替了某种期待的数据状态值.

原文:MongoDB: 原子性和事务

分布式事务-两阶-三阶段提交
mongodb拥有事务的解决方案
												

MongoDB: 原子性和事务的更多相关文章

  1. 在 MongoDB 上模拟事务操作来实现支付

    我们的产品叫「学海密探」,属于在线教育行业,产品需要有支付功能,然而支付最蛋疼是什么?有人会说是支付宝和微信等支付接口的接入开发!没错,但支付接口的开发算是比较简单的了,我觉得凡是跟钱有关系的操作最重 ...

  2. MongoDB 4.0 事务实现解析

    MongoDB 4.0 引入的事务功能,支持多文档ACID特性,例如使用 mongo shell 进行事务操作 > s = db.getMongo().startSession() sessio ...

  3. cassandra mongodb选择——cassandra:分布式扩展好,写性能强,以及可以预料的查询;mongodb:非事务,支持复杂查询,但是不适合报表

    Of course, like any technology MongoDB has its strengths and weaknesses. MongoDB is designed for OLT ...

  4. MongoDB 事务,复制和分片的关系

    摘要:本文尝试对Mongo的复制和分布式事务的原理进行描述,在必要的地方,对实现的正确性进行论证,希望能为MongoDB内核爱好者提供一些参考. 1.前言 MongoDB基于wiredTiger提供的 ...

  5. Redis的事务不是原子性的

    1.事务的四大特性 原子性(Atomicity):化学中的原子指不可再分的基本微粒,数据库中原子性强调事务是一个不可分割的整体,事务开始后所有操作要么全部成功,要么全部失败,不可能停滞在中间某个环节. ...

  6. 【翻译】MongoDB指南/CRUD操作(三)

    [原文地址]https://docs.mongodb.com/manual/ CRUD操作(三) 主要内容: 原子性和事务(Atomicity and Transactions),读隔离.一致性和新近 ...

  7. MongoDB基础

    1.概念及特点 说明:由于部分语句中$ 符号无法正常显示,使用¥代表 概念 MongoDB是一个基于文档的分布式的开源的NoSQL数据库,文档的结构为BSON形式,每一个文档都有一个唯一的Object ...

  8. [轉]redis;mongodb;memcache三者的性能比較

    先说我自己用的情况: 最先用的memcache ,用于键值对关系的服务器端缓存,用于存储一些常用的不是很大,但需要快速反应的数据 然后,在另一个地方,要用到redis,然后就去研究了下redis. 一 ...

  9. 关于mongodb ,redis,memcache

    先说我自己用的情况: 最先用的memcache ,用于键值对关系的服务器端缓存,用于存储一些常用的不是很大,但需要快速反应的数据 然后,在另一个地方,要用到redis,然后就去研究了下redis. 一 ...

随机推荐

  1. 【Java 线程的深入研究2】常用函数说明

    ①sleep(long millis): 在指定的毫秒数内让当前正在执行的线程休眠(暂停执行) ②join():指等待t线程终止. 使用方式. join是Thread类的一个方法,启动线程后直接调用, ...

  2. 动态生成的DOM不会触发onclick事件的原因及解决方法

    最近朋友在做一个项目的时候,遇到动态加载微博内容,然后点击“展开评论”后获取该微博的所有评论.这里使用了动态加载的<span mid='123456789′ class='get_comment ...

  3. NHibernate初学四之关联一对一关系

    1:数据库脚本,创建两张表T_Area.T_Unit,表示一个单位对应一个地区,在单位表中有个AreaID为T_Area表中的ID: CREATE TABLE [dbo].[T_Area]( [ID] ...

  4. redis客户端使用密码

    ./redis-cli  -h 127.0.0.1 -p 6379 -a password

  5. 使用rlwrap调用sqlplus中历史命令

    此文来自http://www.cnblogs.com/mchina/archive/2013/03/08/2934473.html 在此谢谢原创作者. 在Linux中运行SQL*Plus,不能调用历史 ...

  6. JS 操作iframe

    很多人一直都有个想法,要是可以随心所欲的操作iframe就好了.这样静态页面也就有了相当于后台动态页面php,jsp,asp中include,require实现统一多页面布局的能力. 通过Javasc ...

  7. 《C++ Primer Plus》第15章 友元、异常和其他 学习笔记

    友元使得能够为类开发更灵活的接口.类可以将其他函数.其他类和其他类的成员函数作为友元.在某些情况下,可能需要前向声明,需要特别注意类和方法声明的顺序,以正确地组合友元.潜逃类是在其他类中生命的类,它有 ...

  8. openstack 安装部署

    环境准备 本次搭建的是openstack kilo版本,计算节点和控制节点采用linux bridge的方式连接 1.两台服务器 controller 172.16.201.9 compute01 1 ...

  9. codereviw得到的一些经验

    1.设置display为none的元素,它的背景图依然会被下载.所以最好是等到该元素需要显示时才给他加上相应的有背景图的class. 2.css中虽然ID选择器的优先级比较高,效率也比较高,但灵活性差 ...

  10. 关于js的面向对象设计

    function Person( name, age ){ this.name = name; this.age = age; this.sleep = function(){ alert( this ...