MongoDB 4.0将支持多文件交易功能,向资料完整性再进一步
预计2018年夏天上市的MongoDB 4.0,预计将支持多文件交易,以保证资料完整性,这项关联性资料库才能提供的关键特性。
MongoDB技术长暨创办人Eliot Horowitz表示,MongoDB将会是兼顾速度与弹性,使用文件模型并确保ACID原则的资料库。
Eliot Horowitz说,在MongoDB处理交易,将会像使用关联式资料库一样,开发者能使用熟悉的多语句语法,他特别强调,在MongoDB增加的多文件交易功能,完全不会影响效能,在MongoDB 4.0交易将能在单个複本集运作,到了MongoDB 4.2将支持跨分片部署交易。
MongoDB以文件模型串起关联的资料,提供使用关联架构描述多个独立表格关係的特性,而目前MongoDB单一文件的不可分割特性,也已经提供大多数应用程式维持资料完整性所需要的交易语意,不过,接下来新增的多文件交易,能让开发者更容易的将MongoDB应用在更多严谨的情境中。
MongoDB即将提供完整的资料完整性,要溯源至3年前併购来的WiredTiger储存引擎。Eliot Horowitz细数为达到资料完整性,MongoDB的技术发展史,从3.0版本开始 具备文件级的并行控制以及压缩功能,还提供MVCC这种像是PostgreSQL关联式资料库,确保交易功能的储存层基础功能。
在MongoDB 3.2的增强型共识协定,能让主要複本集成员的网路分区快速的从故障中恢复,并更严谨的确保写入的持久性。MongoDB 3.6开始提供因果一致性与 Retryable Writes,让系统能跨分散式丛集节点协调用户与服务器端的运作,管理交易命令的前后关係。
Eliot Horowitz提到MongoDB 4.0已经完成的功能,是支持複本集时间点读取,不只对于维持交易一致性十分关键,在日常读取运作上也很有用。
基于上述这些基础,再加上即将完成的多文件分散式交易,MongoDB将能在单个複本集以及跨分片部署提供全域资料一致性。无论资料储存的方式,开发者可以完全信任系统提供的交易完整性,并专注于应用程式功能开发,而不需要在应用程式层特别撰写交易完整性的逻辑。