zoukankan      html  css  js  c++  java
  • MongoDB存储引擎(下)——In-Memory

      前两篇文章分别介绍了MMAPv1WiredTiger,这两个存储引擎都是会将数据持久化存储到硬盘的,除此之外,MongoDB也有只将数据存储在内存的存储引擎,那就是In-Memory

      In-Memory存储引擎将数据库数据都存储在内存中,只将少量的元数据和诊断日志、临时数据存储到硬盘文件中,避免了磁盘I/O操作,查询速度很快。In-Memory存储引擎更多特点如下:

    1. 文档级别的并发控制

      In-Memory存储引擎使用文档级别锁,同一时刻多个写操作可以修改同一个集合中不同的文档,但不能修改同一个文档,必须以序列化方式执行。

    2. 内存使用

      In-Memory需要将数据库的数据、索引和操作日志等内容存储到内存中。可以通过参数--inMemorySizeGB设置它占用的内存大小,默认为:50% of RAM - 1GB

    3. 持久化

      In-Memory不需要单独的日志文件,不存在记录日志和等待数据持久化的问题。当MongoDB实例关机或系统异常终止时,所有存储在内存中的数据都将会丢失。

    4. 记录oplog

      In-Memory虽然不将数据写入硬盘,但还是会记录oplog。利用这个特性,可以在集群中使用In-MemoryMongoDB作为主数据库,使用WiredTigerMongoDB作为备份数据库,然后将主数据库的oplog推送给备份数据库进行持久化存储,这样即使主数据库关机或异常崩溃,重启后还可以从备份数据库中同步数据。

  • 相关阅读:
    最短路一类问题总结
    [Luogu] UVA1205 Color a Tree
    [Luogu] UVA1193 Radar Installation
    [Luogu] P2859 [USACO06FEB]Stall Reservations S
    [Luogu] P1248 加工生产调度
    [Luogu] P3694 邦邦的大合唱站队
    [Luogu] CF229D Towers
    windows server清理文件
    python连接ES进行数据过滤删除,新增查询、创建索引功能
    ES以更新时间为标准,分离数据
  • 原文地址:https://www.cnblogs.com/wujuntian/p/8458901.html
Copyright © 2011-2022 走看看