写点什么

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:003101
用户头像

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

关注

评论

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

设计一款照片一键加水印的小工具

DS小龙哥

3月月更

电商系统微服务拆分

风中奇缘

#架构实战营 「架构实战营」

模块一作业

Dean.Zhang

架构实战营

毕业总结:

Anlumina

#架构实战营

Centos7安装单机版Redis

云原生

redis Redis 数据结构

模块九毕业设计

沈益飞

架构训练营 架构训练营4

架构实战营四期-毕业设计

木几丶

「架构实战营」

PHP session反序列化漏洞原理解析

网络安全学海

网络安全 信息安全 渗透测试 WEB安全 漏洞挖掘

电商系统的微服务拆分方案设计

五月雨

架构实战营 「架构实战营」

作业六

Geek_f3e842

架构实战营

架构实战营 模块九

架构实战营 「架构实战营」 模块九

我的前端技术思考

PingCode研发中心

架构 Worktile angular dialog PingCode

毕业设计

Anlumina

「架构实战营」

毕业设计 - 电商秒杀系统

圈圈gor

#架构实战营 「架构实战营」

架构实战营四期-毕业总结

木几丶

「架构实战营」

架构实战营:模块六业

刘璐

关于DDD的一些思考

meacial

DDD 架构设计 领域模型

电商系统微服务架构拆分

李大虾

#架构实战营 「架构实战营」

模块6作业:电商系统微服务拆分

炎彬

「架构实战营」

KCP协议:从TCP到UDP家族QUIC/KCP/ENET

zhoulujun

网络加速 KCP 游戏加速 quick 带宽优化

拆分电商平台为微服务

smile

【51单片机】矩阵键盘

謓泽

3月月更

到底为什么不建议使用SELECT *?

蝉沐风

MySQL

Flink对接kafka

云原生

flink kafka 流计算 实时计算

模块六

Geek_28cf33

电商系统微服务拆分

张逃逃

Orbiton JS:用于构建 UI 的 JavaScript 库

devpoint

JavaScript 3月月更 Orbiton JS

模块六作业

Mr小公熊

架构训练营毕业总结

沈益飞

架构训练营 架构师训练营 4 期

kratos 微服务框架商城实战初识 kratos

Aliliin

Go Kratos

架构实战营毕业总结

架构实战营 「架构实战营」

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