Storage > Journaling
在本页面将从以下两点论述:
为了在发生故障时提供持久性,MongoDB使用预写日志记录到磁盘journal文件中。
日志记录和WiredTiger存储引擎
重要
本节中提到的log是指WiredTiger预写日志(即日志),而不是MongoDB日志文件。
WiredTiger使用检查点以提供磁盘上数据的一致视图,并允许MongoDB从最后一个检查点恢复。但是,如果MongoDB在检查点之间意外退出,则需要日记来恢复上一个检查点之后发生的信息。
注意
从MongoDB 4.0开始,对于使用WiredTiger存储引擎的副本集成员,不能指定--nojournal选项或storage.journal.enabled:false。
使用日志记录的恢复过程:
1.在数据文件中查找最后一个检查点的标识符。2.在日记文件中搜索与最后一个检查点的标识符匹配的记录。3.从上一个检查点开始,将操作应用于日志文件。
于3.2版本中变更
使用日志功能,WiredTiger为每个客户端发起的写操作创建一个日记记录。日志记录包括由初始写入引起的任何内部写入操作。例如,对集合中文档的更新可能会导致对索引的修改;WiredTiger创建单个日志记录,其中包含更新操作及其关联的索引修改。
MongoDB将WiredTiger配置为使用内存缓冲来存储日记记录。线程进行协调以分配并复制到其缓冲区中。全部日记记录最多可缓存128kB。
WiredTiger在以下任一情况下将缓冲的日记记录同步到磁盘:
注意
如果writeConcernMajorityJournalDefault设置为true,则写关注“majority”会隐含j: true。
重要
在两次写操作之间,虽然日记记录保留在WiredTiger缓冲区中,但是强制关闭mongod可能会导致更新丢失。
同样请参阅serverStatus命令在“wiredTiger.log”字段中返回有关WiredTiger日记统计信息的信息。
对于日志文件,MongoDB在dbPath目录下会创建一个名为“journal”的子目录。WiredTiger日志文件的名称具有以下格式WiredTigerLog.<sequence>,其中<sequence>是从0000000001开始的零填充数字。
日志记录
日志文件包含每个客户端的初始写操作记录:
压缩
默认情况下,MongoDB将WiredTiger配置为对其日记数据使用snappy压缩。要指定其他压缩算法或不进行压缩,请使用storage.wiredTiger.engineConfig.journalCompressor设置。详细信息请参阅Change WiredTiger Journal Compressor。
注意
如果日志记录小于或等于128字节(WiredTiger的最小值日志记录大小),则WiredTiger不会压缩该记录。
日志文件大小限制
MongoDB的WiredTiger日志文件的大小限制为最大大约为100 MB。
预分配
WiredTiger预分配日志文件。
日志和内存存储引擎
从MongoDB Enterprise的3.2.6版本开始,内存存储引擎就成为MongoDB常规可用性(GA)的一部分。因为其数据保留在内存中,所以没有单独的日志。使用写关注j:true的写操作会被立即确认。
如果副本集中任何有投票权的成员使用内存存储引擎,则必须将writeConcernMajorityJournalDefault设置为false。
注意
从版本4.2(以及4.0.13和3.6.14)开始,如果副本集成员使用内存存储引擎(投票或非投票),但副本集的writeConcernMajorityJournalDefault设置为true,则副本集成员会记录一条启动警告。
将writeConcernMajorityJournalDefault设置为false,MongoDB在确认写入之前不会等待w:“majority”的写操作被写入磁盘日志。因此,majority写操作可能会在给定副本集中的大多数节点瞬时丢失(比如崩溃和重启)时回滚。
同样请参阅内存存储引擎:持久性
原文链接:
本文分享自 Mongoing中文社区 微信公众号,前往查看
如有侵权,请联系 cloudcommunity@tencent.com 删除。
本文参与 腾讯云自媒体同步曝光计划 ,欢迎热爱写作的你一起参与!
扫码关注腾讯云开发者
领取腾讯云代金券
Copyright © 2013 - 2025 Tencent Cloud. All Rights Reserved. 腾讯云 版权所有
深圳市腾讯计算机系统有限公司 ICP备案/许可证号:粤B2-20090059 深公网安备号 44030502008569
腾讯云计算(北京)有限责任公司 京ICP证150476号 | 京ICP备11018762号 | 京公网安备号11010802020287
Copyright © 2013 - 2025 Tencent Cloud.
All Rights Reserved. 腾讯云 版权所有