MongoDB存储引擎

本文介绍了MongoDB的存储引擎,重点关注WiredTiger的优势,如Btree结构、文档级别的并发控制和数据压缩。WiredTiger包含多个文件,用于存储配置、数据和元数据。写请求处理过程涉及Cache、WAL和定期checkpoint,确保数据完整性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

存储引擎概述

存储引擎是MongoDB的核心组件,负责管理数据如何存储在硬盘和内存上。MongoDB支持的存储轻音有MMAPv1,WiredTiger和InMemory。InMemory表示只将数据存储在内存中,并且只把诊断日志和元数据(meta-data)信息存储在硬盘文件中,由于不需要和磁盘进行IO操作,就可以获取到所需要的数据,InMemroy引擎大幅度降低了查询的延迟(latency)。从MongoDB3.2开始,默认的存储引擎是WiredTiger,3.2之前默认的存储引擎是MMAPv1,MongoDB4.x以后的版本不再支持MMAPv1.

WiredTiger存储引擎优势

  1. 文档空间分配方式:WiredTiger是Btree结构,MMAPv1为线性存储,需要Padding
  2. 并发级别:WiredTiger文档级别,MMAPv1是表级
  3. 数据压缩:WiredTiger默认snappy,并且可选zlib,MMAPv1默认无压缩,空间可能相差十几倍。
  4. 内存使用:WiredTiger可以指定内存的使用大小
  5. Cache使用:WT引擎使用了二阶缓存WiredTiger Cache,File System Cache来保证Disk上的数据的最终一致性

WiredTiger引擎包含的文件和作用

在这里插入图片描述<

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值