- mongodb - 在 MongoDB mapreduce 中,如何展平值对象?
- javascript - 对象传播与 Object.assign
- html - 输入类型 ="submit"Vs 按钮标签它们可以互换吗?
- sql - 使用 MongoDB 而不是 MS SQL Server 的优缺点
我们最近使用 YCSB (https://github.com/brianfrankcooper/YCSB/wiki) 对 Oracle 10g 和 MongoDB 进行了基准测试,当我们尝试增加 1,000,000 个数据集的线程数时,Oracle 的性能在 4 个线程后保持不变,但 MongoDB 的性能一直越来越好,直到 8 个线程和之后只有读取更好,写入和更新(操作/秒)保持不变。
我们在 2 CPU Xeon 四核(共 8 核)+ 8 GB RAM 的 LAN 上运行此基准测试。
我们观察到,与单线程客户端相比,MongoDB 在多线程客户端上的性能更好,我的问题是:当 MongoDB 可以在更多负载下表现更好时,为什么它不能在更少负载下做同样的事情(比如说只是一个几个线程)通过利用多个核心?
最佳答案
在单核上处理请求在逻辑上非常简单。只需拥有接收请求并处理它的代码即可。
在 2 个内核上处理单个请求并不是那么简单,因为这样做需要您将请求分解为组件、分包工作、同步答案,然后构建单个响应。如果你做这个工作,虽然你可以减少挂钟时间(墙上的时钟看到多少时间过去),但你总是会让请求花费更多的 CPU 时间(消耗的总 CPU 资源)。
在像 MongoDB 这样的系统中,您希望有很多不同的客户端发出请求,因此没有必要尝试并行处理单个请求,并且完全有理由不这样做。
更大的问题是为什么 Oracle 在 4 个 CPU 之后没有增加并发性。可能的原因有很多,但一个合理的猜测是您遇到了某种锁定,这是保证一致性所必需的。 (MongoDB 不提供一致性,因此避免了这种类型的瓶颈。)
关于mongodb - 与单线程客户端相比,为什么 MongoDB 使用多线程客户端性能更好?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6544037/
此代码似乎在启用优化的广泛使用的编译器上中断,尽管它在 Visual Studio 中运行良好。 struct foo { foo(int a) { s[0] = '0'+a%10;s[1]
我想要一个图表,其中有一个单线箭头,如下所示: 1 2 3 4 5 或者像这样(其中/假设是一个箭头:)): \/ -----------------
我正在为 Java 编写自定义规则。有两个 Tree.KIND 实例(STRING_LITERAL 和 ASSIGNMENT)需要捕获。有一个特定的行,字符串文字和赋值的逻辑都会引发问题。但 Sona
Rosettacode.org 在 Ruby 中有这个出色的单行 FizzBuzz 解决方案。 1.upto(100){|n|puts'FizzBuzz '[i=n**4%-15,i+13]||n
很多时候我使用了这个命令,它在当前目录打开了一个临时的 HTTP 服务器: python3 -m http.server 现在我需要接收文件,有没有打开ftp服务器的一行命令? 我只是在寻找一个命令行
相关主题 std::unique_ptr, deleters and the Win32 API 要将 Win32 句柄用作 RAII,我可以使用以下行 std::unique_ptr::type,
我认为必须有一个单行 Guava 解决方案来将一个不可变列表转换为另一个不可变列表,但我找不到它。假设我们有以下对象: ImmutableList input = ImmutableList.of("
我有以下 Highcharts ( http://www.highcharts.com ) 散点图。请注意,轴从 -10 开始,到 10 停止,中间为 0。我希望每条 0 线的宽度或颜色都与其他线不同
我有一个项目需要将一个视频文件与另一个音频文件合并。预期的输出是一个视频文件,其中包含来自实际视频的音频和合并后的音频文件。输出视频文件的长度将与实际视频文件的大小相同。 是否有单行 FFMPEG 命
我在 python3 类中有 2 个列表: self.keys = ["a","b","c","d"] self.values = [1,2,3,4] len(self.keys) == len(se
我有一个不同长度的数组列表,我想将它们组合成一个最大维度的矩阵,并在末尾填充零。例如(伪代码): combine( [1,2,3], [4,5]) [[1,2,3],[4,5,0]] 这是我目前的解决
例如,给定 i=5 和 n=8,我想生成 [0;0;0;0;1;0; 0;0]。具体来说,我想生成向量 v 以便: v = zeros(n,1); v(i) = 1; 有没有一种(合理的)方法可以在一
我是一名优秀的程序员,十分优秀!