美文网首页
mongodb存储引擎WiredTiger

mongodb存储引擎WiredTiger

作者: 小码弟 | 来源:发表于2018-10-29 22:14 被阅读0次
    th.jpg

    MongoDB2.3后默认采用WiredTiger存储引擎。

    组成

    WiredTiger由三部分组成:

    • Mongos: 负责查询请求的路由和对ShardServer的管理;
    • ConfigServer: 记录全局配置信息
    • ShardServer:完成实际查询和数据提取操作


      p.png

    Transport Layer业务层

    Transport Layer是处理请求的基本单位。Mongo有专门的listener线程,每次有连接进来,listener会创建一个新的线程conn负责与客户端交互,它把具体的查询请求交给network线程,真正到数据库里查询由TaskExecutor来进行。

    p-2.png

    写请求

    WiredTiger的写操作会默认写入Cache,并持久化到WAL(Write Ahead Log),每60s做一次checkpoint,产生快照文件。WiredTiger初始化时,恢复至最新的快照状态,然后根据WAL恢复数据,保证数据的完整性。
    Cache是基于BTree的,节点是一个page,root page是根节点,internal page是中间索引节点,leaf page真正存储数据,数据以page为单位与磁道读写。

    p-3.png

    一致性

    1. WiredTiger使用Copy on Write管理修改操作。修改先放在cache中,并持久化,不直接作用在原leaf page,而是写入新分配的page,每次checkpoint产生新page。
      相关文件:
    • WiredTiger.basecfg: 存储基本配置信息,与ConfigServer有关系
    • WiredTiger.lock: 定义锁操作
    • table*.wt: 存储各张表的数据
    • WiredTiger.wt: 存储table* 的元数据
    • WiredTiger.turtle: 存储WiredTiger.wt的元数据
    • journal: 存储WAL
    1. 一次checkpoint过程
      1. 对每个table*.wt做一次checkpoint,各自的元数据都更新到WiredTiger.wt中
      2. 对WiredTiger.wt做一次checkpoint,将元数据存储到WiredTiger.turtle.set中,整个过程完成之前,原来的WiredTiger.turtle继续发挥作用,保证可用性。待过程完成后,将WiredTiger.turtle.set重命名为WiredTiger.turtle。

    相关文章

      网友评论

          本文标题:mongodb存储引擎WiredTiger

          本文链接:https://www.haomeiwen.com/subject/oxsptqtx.html