【赵渝强老师】MongoDB的MMAPv1存储引擎

在MongoDB 3.2版本以前,MongoDB使用MMAPv1作为默认的存储引擎。在MMAPv1的存储引擎中,包含以下的组成部分:

  • Database

每个Database由一个.ns名称空间文件及若干个数据文件组成。数据文件从0开始编号,依次为.0、.1、.2等。数据文件大小从64MB起,依次倍增,最大为2GB。

  • Namespace

每个Database可以包含多个Namespace名称空间文件,该名称空间对应MongoDB中的集合,名称空间文件文件实际上是一个Hash表,可用于快速定位某个集合的起始位置

  • 数据文件

每个数据文件被划分成多个extent,每个extent只包含一个名称空间的数据。同一个名称空间的所有extent之间以双向链表形式组织。名称空间的元数据里包含指向第一个及最后一个extent的位置指针,通过这些信息,就可以遍历一个名称空间下的所有extent数据。下图说明了名称空间文件与数据文件之间的关系。

  • Extent

每个Extent包含多个Record,该Record对应MongoDB集合中的Document),同一个Extent下的所有Record以双向链表形式组织。

  • Record

每个Record对应mongodb里的一个文档。

视频讲解如下:

MongoDB的MMAPv1存储引擎
【赵渝强老师】MongoDB的MMAPv1存储引擎

下面通过一个简单的示例来演示MMAPv1存储引擎。

(1)创建目录用于保存MMAPv1存储引擎的数据。

powershell 复制代码
mkdir -p /data/mmapv1

(2)编辑配置文件/data/mmapv1/mmapv1.conf,输入下面的内容。

powershell 复制代码
dbpath=/data/mmapv1/
port=27018
fork=true
logpath=/data/mmapv1/mmapv1.log
storageEngine=mmapv1

(3)启动MongoDB服务器端。

powershell 复制代码
mongod --config /data/mmapv1/mmapv1.conf

(4)使用mongoshell连接MongoDB。

powershell 复制代码
mongo --port 27018

(5)在MongoDB中创建一个数据库和一张新的集合,并插入一条数据。

powershell 复制代码
> use mmapv1
> db.test1.insert({name:'Tom',age:18});

(6)查看目录/data/mmapv1下的文件。

powershell 复制代码
tree /data/mmapv1

输出的信息如下:
/data/mmapv1
├── admin.0
├── admin.ns
├── diagnostic.data
│   ├── metrics.2022-04-04T05-18-26Z-00000
│   └── metrics.interim
├── journal
│   └── j._0
├── local.0
├── local.ns
├── mmapv1.0        ---> mmapv1数据库的第一个数据文件。
├── mmapv1.conf
├── mmapv1.log
├── mmapv1.ns       ---> 这是在第(5)步中创建的mmapv1数据库的名称空间文件。
├── mongod.lock
├── storage.bson
└── _tmp
相关推荐
今年不养猪只除草2 小时前
windows版本的时序数据库TDengine安装以及可视化工具
数据库·时序数据库·tdengine
极限实验室4 小时前
Easysearch 磁盘水位线注意事项
数据库
月落星还在4 小时前
Redis 单线程架构:化繁为简的性能哲学
数据库·redis·架构
十五年专注C++开发4 小时前
SQLiteStudio:一款免费开源跨平台的SQLite管理工具
数据库·c++·qt·sqlite
啥都想学的又啥都不会的研究生5 小时前
Redis设计与实现-服务器中的数据库
运维·服务器·数据库·redis·笔记·缓存·性能优化
m0_748229995 小时前
redis 使用
数据库·redis·缓存
Foolforuuu5 小时前
什么样的场景适用redis?redis缓存是什么?
数据库·redis·缓存
m0_748234085 小时前
redis 清理缓存
数据库·redis·缓存
智享AI5 小时前
阿里云工作空间与Ollama(一)
数据库·阿里云·云计算
聆风吟º5 小时前
阿里云操作系统控制台实战评测:提升云资源管理与监控效率
数据库·阿里云·云计算