当前位置: 首页 > article >正文

【赵渝强老师】MongoDB写入数据的过程

在这里插入图片描述
在MongoDB数据更新时,WiredTiger存储引擎使用预写日志的机制先将数据更新写入到Journal日志文件中。然后在创建检查点操作开始时,再将日志文件中记录的操作刷新到数据文件。换句话说,通过预写日志和检查点机制可以保证将数据更新持久化到数据文件中,并实现数据的一致性。

视频讲解如下

【赵渝强老师】MongoDB写入数据的过程

在检查点(Checkpoint)操作开始时,WiredTiger存储引擎将提供指定时间点的数据库快照,该快照反映的是MongoDB当前内存中的数据情况。当向磁盘写入数据时,WiredTiger存储引擎将快照中的所有数据以一致性方式写入到MongoDB的数据文件上,并保证数据文件和内存数据是一致性的。由于检查点是定期执行,因此检查点操作能够缩短MongoDB从Journal日志文件恢复数据的时间。在默认情况下,WiredTiger存储引擎创建检查点的时间间隔是60秒或产生2GB的Journal日志信息文件。在WiredTiger存储引擎创建新的检查点期间,上一个检查点仍然是有效的。这意味着即使MongoDB在创建新的检查点期间遭遇到错误而异常终止运行,只要重启MongoDB就能从上一个有效的检查点开始恢复数据。当新的检查点创建成功后,WiredTiger存储引擎以原子方式更新元数据表使其引用新创建的检查点,同时会将老的检查点占用的磁盘空间释放。

下图说明了MongoDB写入数据时,MongoDB的预写日志机制及与产生检查点操作之间的关系。
在这里插入图片描述


http://www.kler.cn/a/467504.html

相关文章:

  • 【Redis经典面试题七】Redis的事务机制是怎样的?
  • Redis--高可用(主从复制、哨兵模式、分片集群)
  • 单片机-独立按键矩阵按键实验
  • 【ArcGISPro/GeoScenePro】检查多光谱影像的属性并优化其外观
  • 让css设置的更具有合理性
  • npm install --global windows-build-tools --save 失败
  • 【redisson】redisson分布式锁原理分析
  • 【深度学习】交叉熵:从理论到实践
  • 专业140+总分400+中国海洋大学819信号与系统考研综合考研经验中海大电子信息与通信工程,真题,。大纲,参考书。
  • 【go类库分享】go rate 原生标准限速库
  • 旷视科技Java面试题及参考答案
  • AWS IAM基础知识
  • ‘元素.style.样式名‘获取不到样式,应该使用Window.getComputedStyle()获取正真的样式
  • 什么是 AJAX ?
  • CentOS7 使用yum报错:[Errno 14] HTTP Error 404 - Not Found 正在尝试其它镜像。
  • 【VScode】设置代理,通过代理连接服务器
  • 【CVPR 2024】【遥感目标检测】Poly Kernel Inception Network for Remote Sensing Detection
  • 【2025软考高级架构师】案例题重点知识——第三部分
  • 反直觉导致卡关-迫击炮谜题
  • unity学习4:git和SVN的使用差别
  • PHP语言的计算机基础
  • 探索最新的编程技术趋势:AI 编程助手和未来的编程方式
  • 瑞吉外卖项目学习笔记(十一)分页查询订单列表
  • 学习随笔:word2vec在win11 vs2022下编译、测试运行
  • CSP初赛知识学习计划
  • Spring Cloud Security集成JWT 快速入门Demo