存储引擎概述
存储引擎是MongoDB的核心组件,负责管理数据如何存储在硬盘和内存上。MongoDB支持的存储轻音有MMAPv1,WiredTiger和InMemory。InMemory表示只将数据存储在内存中,并且只把诊断日志和元数据(meta-data)信息存储在硬盘文件中,由于不需要和磁盘进行IO操作,就可以获取到所需要的数据,InMemroy引擎大幅度降低了查询的延迟(latency)。从MongoDB3.2开始,默认的存储引擎是WiredTiger,3.2之前默认的存储引擎是MMAPv1,MongoDB4.x以后的版本不再支持MMAPv1.
WiredTiger存储引擎优势
- 文档空间分配方式:WiredTiger是Btree结构,MMAPv1为线性存储,需要Padding
- 并发级别:WiredTiger文档级别,MMAPv1是表级
- 数据压缩:WiredTiger默认snappy,并且可选zlib,MMAPv1默认无压缩,空间可能相差十几倍。
- 内存使用:WiredTiger可以指定内存的使用大小
- Cache使用:WT引擎使用了二阶缓存WiredTiger Cache,File System Cache来保证Disk上的数据的最终一致性
WiredTiger引擎包含的文件和作用
<