Mongodb(1)——存储引擎WiredTiger的使用

本文深入探讨了MongoDB的WiredTiger存储引擎,从DB和Collection的创建过程,到WiredTiger如何组织数据进行存储。在创建DB时,MongoDB会检查是否存在并使用预设的storage engine创建DatabaseCatalogEntry。Collection的创建涉及生成唯一的文件名,每个db.collection对应一个文件。WiredTiger通过将db.collection转换为唯一字符串作为文件名,存储KV对并使用自增键作为索引。文章还提到了数据组织的推测和元数据的可能存储位置。
摘要由CSDN通过智能技术生成

wiredtiger

DatabaseHolder:负责创建、关闭、获取DB。
Database:Database的入口,是Database的类的实现,提供了Collection的创建销毁接口。
StorageEngine:存储引擎的抽象类,各类存储引擎事实上都是继承于StorageEngine。
KVEngine:KVStorageEngine实际是调用这个类的操作。
WiredTigerKVEngine:KVEngine实际也只是一个抽象类,具体的实现由WiredTigerEngine完成,我们关心的Wiredtiger存储引擎的工作就是从这开始的,从上层来看,这里就是WiredTiger存储工作的起始;而从下层看,这里只是向外提供了一层接口,真正的使用是在各接口中调用WT的方法。
RecordStore:各类存储引擎的实现类具体工作只是创建RecordStore(以下简称RS),真正负责数据的读取存储都是在RS中完成。
ServiceContext:负责在启动时设置系统环境,StorageEngine的设置也是在其中完成。
CatalogEntry:各类CatalogEntry,几乎每一层概念都会有一个CatalogEntry,其会有一些辅助功能,但这种类的意义我还不是太理解。

1. DB的创建

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值