写点什么

MongoDB 4.0 有望支持跨文档事务

  • 2018-02-23
  • 本文字数:1023 字

    阅读完需:约 3 分钟

看新闻很累?看技术新闻更累?试试下载 InfoQ 手机客户端,每天上下班路上听新闻,有趣还有料!

自 MongoDB 并购了 WiredTiger 及其关系数据库存储引擎以来,很多技术专家一直翘首以待 MongoDB 何时提供对跨文档事务(multi-document transaction)的支持。MongoDB 在本周宣布,跨文档事务有望于今年夏天加入到 MongoDB 4.0 中。

MongoDB 的 Grigori Melnik 宣称,“80% 到 90% 的应用是完全不需要跨文档事务的”。然而他的说法有待商榷,在层次数据库中很有可能存在大量的反规范化(denormalized)数据,此类数据需要支持多地同时更新以确保一致性。Melnik 继续指出:

此外,一些开发人员和数据库管理员受限于业已存在 40 多年的关系数据建模,总是误以为多表或多文档事务是所有数据库的要求,无论实际需要构建何种数据模型。其他一些人则担心,虽然他们的应用当前不需要跨文档事务,但将来可能会需要,他们不希望过度扩展他们的数据库。

跨文档事务是 ACID 的基石。MongoDB 自 3.0 版起,开始支持跨文档事务。在 3.0 版中,MongoDB 具备了多版本并发控制(MVCC)技术,该技术是一种快照隔离技术,通常是由PostgreSQL 和Oracle 等关系数据库提供。最新版本的SQL Server 也使用MVCC 实现其“内存优化”表。

MongoDB 3.2 增加了对“读取关注”(Read Concern) 的支持。在3.2 版之前,客户只有知道进行通信的节点时,才会接收数据。读取关注功能允许客户请求为大多数节点所知的数据。需要注意的是,根据文档介绍,“无论读取的关注级别,节点上的最新数据可能并未反映系统中数据的最新版本。”

MongoDB 之后在 3.6 版中提供了其所宣称的“因果一致性”。在以前的MongoDB 版本中,并不能保证操作是按指定顺序进行的。例如,当删除一组记录后再执行一次读取操作时,可能会返回刚被删除的记录。使用因果一致性,用户可以指明读取操作取决于写操作的结果,确保了在执行读取操作之前先完成删除操作。

最后一点,MongoDB 4.0 将提供执行一致性读取的能力。也就是说,MongoDB 只返回数据库在读取操作开始时已知的数据。正如在InfoQ 文章“[事务隔离级别和脏读的快速入门] http://www.infoq.com/cn/articles/Isolation-Levels )”中所介绍的,以前版本的 MongoDB 返回的结果可能和任何时间点都不一致。它甚至可能跳过一些文档,或是在一次查询中返回同一文档的多个版本。

希望想要试用跨文档事务的开发人员,积极加入到 MongoDB 4.0 beta 计划中。

查看英文原文: MongoDB 4.0 to Include Multi-Document Transactions

2018-02-23 18:002906
用户头像

发布了 391 篇内容, 共 140.0 次阅读, 收获喜欢 257 次。

关注

评论

发布
暂无评论
发现更多内容

爱情从来都不是简单的事

阿泽🧸

520单身福利

缅怀袁老

topsion

随笔杂谈

【音视频】基于声网实时音视频能力的音视频质量体系建设

轻口味

音视频 WebRTC 声网 质量指标

ArrayList与LinkedList性能大PK

Damon

java基础 5月日更

模块四:课后作业

菲尼克斯

架构实战营

InnoDB 锁类型及其分析

luojiahu

innodb 死锁 间隙锁 意向锁

模块4作业4

杨彬

#架构实战营

设计千万级学生管理系统的考试试卷存储方案

Vincent

架构训练营

【渗透测试】hackthebox靶场之ScriptKiddie

Thrash

Python数据科学基础-Pandas介绍

五分钟学大数据

数据科学 5月日更

架构学习笔记:读写分离

风翱

架构 5月日更

加油!未来的每一天

Sherry

520单身福利 520 单身福利

感恩父母

若兮

520 单身福利

打击挖矿和交易行为!

CECBC

自我复盘

lenka

5月日更

网络攻防学习笔记 Day22

穿过生命散发芬芳

5月日更 网络攻防

Flink的程序结构

大数据技术指南

flink 5月日更

☕【JVM技术之旅】彻底弄清楚Minor GC和Major GC及Full GC

洛神灬殇

JVM 垃圾回收 GC 5月日更

今年过一次不一样的520!

liuzhen007

520单身福利 520 单身福利

ORACLE数据库应用开发三十忌

老猿Python

数据库 oracle 程序开发 数据库应用开发

🚄【Redis 干货领域】帮你完全搞定Cluster原理(架构篇)

洛神灬殇

redis redis集群 5月日更 redis架构

密码学基础

escray

学习 极客时间 安全 5月日更 安全攻防技能30讲

加密货币终将替代黄金?总价值已接近私人持有黄金价值

CECBC

模块4-作业

yu

编辑器的江湖

ES_her0

5月日更

如何提升Hadoop访问对象存储US3的效率?我们做了这些技术实践

UCloud技术

大数据 hadoop

双峰哲学 - 一种深度工作的哲学

石云升

学习 职场经验 5月日更

Vue-2-常用指令

Python研究所

520 单身福利

C语言不完全类型是什么?有什么用途?

不脱发的程序猿

C语言 C语言不完全类型

Python自动化神器-Fabric

小圆子

520 单身福利

Python - 日志处理(logging模块)

若尘

日志 log Python编程 5月日更

MongoDB 4.0有望支持跨文档事务_架构_Jonathan Allen_InfoQ精选文章