- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
存储引擎充当 mongo db 服务器和物理磁盘之间的接口(interface),决定需要多少内存,还支持集合级别锁定。我的问题是3.0版本之前发生了什么?谁在存储引擎之前分配内存?而M MAP之前的锁定机制是如何工作的
最佳答案
我们称其为 MMAPv1 - MongoDB
的原始存储引擎,因为它内部使用 mmap
调用来实现存储管理。让我们看看 MMAP 是什么?系统调用看起来像。在 Linux 上,它讨论内存分配,或者将文件或设备映射到内存。导致页面起始地址并持续最多长度字节从文件描述符描述的对象映射到某个偏移量。那么,这实际上意味着什么呢?
嗯,MongoDB
实际上需要一个放置文档的地方。它将文档放入文件中。为此,它首先分配一个大文件。假设它在磁盘上分配了一个 100GB 的文件。因此,我们最终在磁盘上得到了 100GB 的文件。磁盘在实际磁盘上可能物理上连续,也可能不连续,因为在该层之下存在一些算法来控制磁盘上的实际空间分配。但从我们的角度来看,它是一个 100GB 的连续文件。如果MongoDB
调用mmap
系统调用,它可以将这个100GB文件映射到100GB虚拟内存中。为了获得这么大的虚拟内存,我们需要在 x64 机器上。这些都是page-sized 。因此操作系统上的页面大小要么是 4k,要么是 16k。所以,100GB的虚拟内存里有很多这样的东西。操作系统将决定内存中可以容纳什么。所以,假设盒子的实际物理内存是32GB,那么如果我们去访问这个内存空间中的其中一个页面,它在任何给定时间都可能不在内存中。操作系统决定哪些页面将位于内存中。我们将内存中可用的显示为绿色。因此,当我们去阅读文档时,如果它到达内存中的页面,那么我们就得到了它。如果它到达不在内存中的页面(白色页面),操作系统必须将其从磁盘中取出。
<子> source
MMAPv1存储引擎提供
集合级并发(锁定)。 MongoDB
内的每个集合都是它自己的文件(可以在 ~\data\db
中看到)。如果在同一个集合上触发多个 write 操作,则必须等待另一个操作完成。这是一个多读者。特定集合一次只能进行一次写入。
允许就地更新。因此,如果文档位于可用(绿色)页面之一中并且我们对其进行更新,那么我们将尝试就地更新它。如果我们无法更新它,那么我们要做的就是将其作为一个整体进行标记,然后将其移动到其他有空间的地方。最后我们将在那里更新它。为了使我们能够就地更新文档而无需移动它,我们使用
2 大小的幂当我们为文档分配初始存储时。因此,如果我们尝试创建一个 3 字节的文档,我们将得到 4 字节。如果我们创建 7 个字节,则为 8 个字节。创建 19 字节文档时为 32 字节。这样,就可以将文档增长一点。那个空间打开了,我们可以更轻松地重复使用它。
此外,请注意,操作系统决定内存中的内容和磁盘上的内容 - 我们对此无能为力。该操作系统对于内存管理来说足够智能。
关于mongodb - Mongodb 中的 MMAP 存储引擎,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29575420/
我想了解 mmap 的工作原理。mmap 的用户级调用如下所示。 void *mmap(void *addr, size_t len, int prot, int flags, int
我正在做一个Bottle驱动程序,我使用 yield 关键字和 mmap.mmap 对象在输出流中发送多个映射文件,如以下代码所示: for mapping in mappings: yield
我来自 C++/RAII 世界。 所以我对何时以及如何调用 mmap.close() 感到困惑[不是 file.close()]。 或者,根本不调用它?会不会漏气? 至于来自 document 的示例
我正在我的大学上操作系统类(class),我们的任务之一是使用 mmap 实现简单的 malloc。现在我开始工作了,我尝试使用 valgrind 来检测遗留的任何错误。不管是否释放内存,valgri
有谁知道 mmap(2) 和 mmap(3) 的区别是什么?手册第 3 节被描述为“本章描述了除第 2 章中描述的实现系统调用的库函数之外的所有库函数。” mmap(3) 不执行系统调用吗? 阅读这两
我不知道我在理解mmap时错过了哪些知识。我就是想不通。但让我这样问我的问题: 我有很多(例如 3 个)文件 block ,其大小分别为 s1、s2、s3。 s1、s2 和 s3 均小于 Mmap (
在 Linux 下: #free -m total used free shared buffers cachedMem:
我正在尝试将 C 库(beaglebone PRU 驱动程序 prussdrv.c)与 Python 连接。我想要访问的特定函数返回一个 mmap 指针,如下所示: int __prussdrv_me
当我调用mmap时: ptr = mmap(NULL, ...); 并要求系统提供一个缓冲区并将文件映射到其中,然后使用 再次调用 mmap ptr2 = mmap(ptr, ...); 尝试
在 Android 上用 Java 内存映射一个大文件效果很好。但是当映射总数超过 ~1.5GB 时,即使有多个映射调用,它也会失败: mmap failed: ENOMEM (Out of memo
我在具有 64G 内存和大量磁盘空间的 debian-64 上运行一个专门的数据库守护进程。它使用磁盘上的哈希表(mmaped)并通过定期 write() 调用将实际数据写入文件。当进行大量更新时,m
C++代码: #include #include #include #include #include using namespace std; #define FILE_MODE (S_I
我想处理一个由 4Kb block 组成的文件。 随着事情的发生,我将编写更多数据并映射新部分,取消映射我不再需要的部分。 当要映射的文件数据总量约为 4Gb 时,仅 4Kb 的 map() 是否太小
大家好,我正在尝试将下面的代码转换为 python(访问树莓派 1Mhz 计时器),我不知道什么时候要映射对象,我们需要 + TIMER_OFFSET (timer = (long long int
我所做的是一个垃圾收集器,使用mmap(2)为用户空间分配空间,这就要求最初分配时可以从任何地方开始,但是后面的分配地址应该是与之前的分配连续,如下所示: page_size = getpagesiz
众所周知,最重要的 mmap() 功能是在许多进程之间共享文件映射。但众所周知,每个进程都有自己的地址空间。 问题是内存映射文件(更具体地说,它的数据)真正保存在哪里,以及进程如何访问这些内存? 我的
什么限制了内存映射文件的大小?我知道它不能大于未分配地址空间的最大连续块,并且应该有足够的可用磁盘空间。但是还有其他限制吗? 最佳答案 您太保守了:内存映射文件可能大于地址空间。 查看 内存映射文件的
如果我使用 mmap 来编写 uint32_t,我会遇到大端/小端约定的问题吗?特别是,如果我在 big-endian 机器上写入一些数据 mmap,当我尝试在 little-endian 机器上读取
所以,对于我最后一年的项目,我使用 Video4Linux2 从相机中提取 YUV420 图像,将它们解析为 x264(本地使用这些图像),然后通过 Live555 将编码流发送到 RTP/RTCP通
是 mmap在它们的效果中调用原子? 也就是说,是否由 mmap 进行了映射更改以原子方式出现在访问受影响区域的其他线程中? 作为试金石,请考虑您执行 mmap 的情况。在一个全为零的文件中(来自线程
我是一名优秀的程序员,十分优秀!