写点什么

MongoDB 1.8 通过 Journaling 日志改善可靠性​

  • 2011-03-28
  • 本文字数:1102 字

    阅读完需:约 4 分钟

面向文档的数据库引擎 MongoDB在3 月16 日发布了1.8 版本。关键的变更包括新增Journaling 日志、提升分片性能以及Shell 的Tab​补全。​

Journaling 日志通过预写式的 Redo 日志为 MongoDB 增加了额外的可靠性。开启该功能时,变更会先写入 Journaling 日志,​定期集中提交(目前是每 100ms 提交一次)​,然后在真实数据上进行这些变更。如果服务器安全关闭,日志会被清除。在服务器启动时,如果存在 Journaling 日志​,则会进行回放。这保证了那些已写入,但在服务器崩溃前还没有回放的​日志能在用户连接前​被执行。​两次提交之间那 100ms 的时间窗口​在未来的版本中有望被缩小。

MongoDB 是​一种 NoSQL 数据库​,不同于 SQL Server 这样的关系型数据库,MongoDB 中数据的基本单位是文档。类似于 JavaScript 对象,文档中包含一系列带有类型的键值对​,这些类型可以是字符串、对象、数组、正则表达式和代码。​这些文档以​BSON 格式存储​,根据文档类型被分组到集合(类似于SQL Server 里的表)中​。Schema 的设计取决于哪些文档应该有自己的集合​,哪些应该被嵌入到其他集合中去。嵌入的文档就像类里的成员对象。在关系型系统中,你会用一张表来存储订单,另一张外键的表来存储订单项。在MongoDB 中,​针对同样的场景,推荐的做法是用一个集合来保存订单,每个订单中保存一个订单项的数组,嵌入其中。​

水平扩展是通过​自动分片来​做的​,​它允许有序的集合数据分布。每个分片都是一组配置成Replica 集的机器​,这意味着分片里的每台机器​都拥有分片数据的完整拷贝。​分片中会自动进行故障转移。MongoDB 会自动将查询引导到合适的分片上,因此应用程序并不需要了解哪个分片持有什么数据元素。​新的Replica 集身份认证功能允许Replica 集的成员之间进行自动身份认证,其中使用了密钥文件和 –keyfile 选项。​

Covered 索引和 Sparse 索引也是该版本中新增加的特性。​Covered 索引允许​在索引本身里存储数据,而​Sparse 索引则会排除掉不包含索引字段的文档。Covered 索引在查询所请求的全部字段​都包含在Covered 索引中时能提升性能,因为不再需要取出完整的文档记录。Sparse 索引在所检索的字段并非经常出现在集合中时能提升性能。目前,Sparse 索引只能有一个字段。​

在MongoDB 的工具集中也有一些变化。mongostat 增加了​discover 模式(–discover)​,它会自动从集群的节点中取回统计信息。​通过_mongodump –oplog_ 和_mongorestore –oplogReplay_ 提供了高级事务日志转储和恢复​功能。​

欲更多地了解该版本中的新特性,请查看 MongoDB 1.8 Webinar

查看英文原文: MongoDB 1.8 Improves Reliability with Journaling

2011-03-28 10:023751
用户头像

发布了 135 篇内容, 共 67.1 次阅读, 收获喜欢 43 次。

关注

评论

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

YashanDB数据库备份与恢复的实战经验分享

数据库砖家

《HarmonyOSNext三方库神装手册:一网打尽炫酷动效开发》

Turing_010

未来的产品经理,更像用户研究员?

Feedalyze

效率工具 产品经理 用户反馈 用户需求 用户反馈管理分析工具

YashanDB数据库备份恢复策略与实操指南

数据库砖家

YashanDB数据库备份与恢复的最佳实践

数据库砖家

《HarmonyOSNext性能暴增秘籍:Node-API多线程通信从阻塞到丝滑的4大方案实战》

Turing_010

YashanDB数据库备份策略及灾难恢复方案解析

数据库砖家

YashanDB数据库备份与恢复最佳实践指南

数据库砖家

YashanDB数据库多副本部署与数据一致性保障教程

数据库砖家

字节的后端实习二面,八股盛宴!

王中阳Go

Go 面试 后端 字节

鸿蒙便捷生活类应用上架流程二

小赵学鸿蒙

运动健康 HarmonyOS应用上架

华为智能穿戴十年,一场智能手表的健康革命

脑极体

AI

DrugCLIP:AI驱动超高通量虚拟筛选引擎,开启后AlphaFold时代创新药物发现新篇章

智源研究院

人工智能 科技 药物 AI+

xHistory for Mac:Mac 终端记录管理的得力助手

晨光熹微

什么是子域名?子域名需要单独注册吗?

防火墙后吃泡面

堡垒机在数据安全中的作用你知道吗?

行云管家

网络安全 数据安全 堡垒机

YashanDB数据库备份恢复流程全攻略

数据库砖家

YashanDB数据库多版本控制功能介绍与应用

数据库砖家

《独立开发工具 • 半月刊》 第 012 期

Immerse

鸿蒙Next仓颉语言开发实战教程:消息列表

幽蓝计划

云上指挥官-云管平台你知多少?

行云管家

云计算 云服务 云管平台 云管理

如何使用第三方库中的@pura/harmony-utils(V1.3.3)申请授权工具类一

小赵学鸿蒙

三方SDK 数码相机

F5 BIG-IQ 4.6.0 - 集中管理 BIG-IP

sysin

F5

Blocs for Mac:Mac 上的网页设计神器

晨光熹微

微信小游戏外包开发流程

北京木奇移动技术有限公司

软件外包公司 游戏外包公司 游戏开发公司

《启信宝2025奶茶趣味报告》:奶茶企业5年激增140%,增至近40万家

合合技术团队

人工智能 报告 #大数据

YashanDB数据库动态扩展能力及实现方式介绍

数据库砖家

SSD指南:理解固态硬盘及透明压缩技术的影响

ScaleFlux

数据中心 数据压缩 企业存储 企业级NVMeSSD

AI智能体的开发

北京木奇移动技术有限公司

软件外包公司 AI技术应用 AI技术外包

ZBrush for Mac:释放 Mac 上的数字雕刻潜能

晨光熹微

MongoDB 1.8通过Journaling日志改善可靠性​_Java_David Cooksey_InfoQ精选文章