Redis Search系列 - 第六讲 基准测试 - Redis Search VS. MongoDB VS. ElasticSearch

目录

    • 一、引言
    • 二、Redis Search 2.x版本的性能提升
    • 三、Redis Search VS. MongoDB VS. ElasticSearch
      • 3.1 测试环境
      • 3.2 100%写 - 基准测试
      • 3.3 100%读 - 基准测试
      • 3.4 混合读/写/搜索 - 基准测试
      • 2.5 搜索延迟分析
      • 3.6 读延迟分析
      • 3.7 写延迟分析
      • 3.8 Redis Search VS. ElasticSearch
      • 3.9 总结

一、引言

本基准测试参考自Redis官方博客,本文仅做汇总说明,具体原文可参见:
https://redis.io/blog/redisjson-public-preview-performance-benchmarking/

二、Redis Search 2.x版本的性能提升

索引了590万篇维基百科摘要,并运行了一个全文搜索查询面板(详情参见这里),不难发现:

  • Redis Search 2.2(结合Redis JSON)比之前的版本快1.7倍,且每个新版本都在持续优化
  • 从v2.0升级到v2.2,将得到更快的写/读/搜索

具体统计结果参见下面2张图:
在这里插入图片描述
在这里插入图片描述

三、Redis Search VS. MongoDB VS. ElasticSearch

3.1 测试环境

基础环境说明

  • 均采用m5d.8xlarge虚拟机,带有本地ssd,
  • 每组压测均由四个虚拟机组成:一个客户端 + 三个数据库服务器。
  • 基准测试客户机和数据库服务器都运行在单独的m5d.8xlarge实例,并放置在最佳网络条件下,这些实例均位于同一可用区内,实现了稳态分析所需的低延迟和稳定的网络性能。

测试集群说明

存储集群组成索引
MongoDB 5.0.3三成员副本集(Primary-Secondary-Secondary)在搜索字段上创建了文本索引(TEXT),以支持文本搜索查询
ElasticSearch 7.1515个分片设置,启用查询缓存,
使用RAID 0阵列的2个本地NVMe SSD
预先创建索引
Redis Search 2.2
Redis JSON 2.0
OSS Redis Cluster v6.2.6,
27个分片均匀分布在三个节点上,
加载了Redis Search 2.2和Redis JSON 2.0 OSS模块
预先创建索引

测试框架
https://github.com/RedisJSON/RedisJSON/tree/master/tests/benchmarks
https://github.com/RediSearch/ftsb/blob/master/docs/enwiki-abstract-benchmark/description.md
https://github.com/RediSearch/ftsb/blob/master/docs/nyc_taxis-benchmark/description.md
https://github.com/brianfrankcooper/YCSB/pull/1577

3.2 100%写 - 基准测试

结合 延迟吞吐量 的综合提升:

  • Redis JSON比Mongodb快5.4倍
  • 比Elastic Search在单独写方面快200倍
  • 99%的Redis请求在不到1.5ms的时间内完成。

注:
Redis JSON是三种方案中唯一在每次写入时自动更新索引的解决方案,
其他均是异步更新索引,需要等待一段时间后才能检索到数据

具体统计结果如下图:
在这里插入图片描述
在这里插入图片描述

3.3 100%读 - 基准测试

注:
此处的读可以理解为根据key直接读取文档,而不是执行全文检索

结合 延迟吞吐量 的综合提升:

  • Redis JSON比MongoDB快12.7倍
  • 比Elastic Search快500倍

在这里插入图片描述

在这里插入图片描述

3.4 混合读/写/搜索 - 基准测试

实际应用程序的工作负载几乎总是混合了读、写和搜索查询。因此,当混合工作负载接近饱和时,理解由此产生的混合工作负载吞吐量曲线就更加重要了。作为起点,我们考虑了 65%搜索35%读取的场景,这代表了一个常见的现实场景,在这个场景中,我们执行的搜索/查询比直接读取更多。65%的搜索35%的读取0%的更新 的初始组合也使ElasticSearch和Redis JSON的吞吐量相等,后续不断切换YCSB工作负载中搜索/读取/更新之间的比率以匹配测试需求。在每个测试变量中,我们都添加了10%的写操作,并以相同的比例降低了搜索和读取百分比。这些测试变化的目标是了解每个产品如何处理数据的实时更新,我们认为这是事实上的架构目标,即 写入立即提交到索引,读取总是最新的

搜索场景
分页查询,双字全文检索,结果按数字属性排序
a paginated two-word query match, sorted by a numeric field

结合对比结果如下:

  • Redis JSON: 持续更新数据并增加写入比例不会影响读取或搜索性能,反而会提高整体吞吐量。
  • ElasticSearch:随着更新比例从0%增加到50%,吞吐量(Ops/sec)从10k下降到2.1k(降低5倍),性能受到显著影响,读取和搜索速度变慢。
  • MongoDB:搜索性能比Redis JSON和ElasticSearch慢两个数量级,最大吞吐量为424 Ops/sec,而Redis JSON为16k Ops/sec。
  • 综合所有混合负载测试
    • Redis JSON在混合工作负载下的吞吐量比MongoDB高50.8倍,比ElasticSearch高7倍。
    • Redis JSON的操作延迟比MongoDB低91倍,比ElasticSearch低23.7倍。
  • 总结: Redis Search几乎不受更新比例影响,吞吐量稳步提升,三者中性能最高;ElasticSearch受到更新比例的显著影响,随着更新比例的提高,读取和搜索速度变慢;MongoDB性能整体最差(比RedisSearch、ElasticSearch慢2个数据级)。

具体测试统计结果如下图:
在这里插入图片描述

2.5 搜索延迟分析

注: 延迟即耗时,即请求平均耗时

在下图中,显示了搜索测试吞吐量为250ops/sec时从p0到p9999的延迟百分位数:

  • Mongodb DB的表现都远远落后于ElasticSearch和Redis JSON。
  • 对比ElasticSearch与Redis JSON,很明显ElasticSearch容易受到更高延迟的影响,这很可能是由垃圾收集(GC)触发或搜索查询缓存丢失引起的。
  • Redis JSON的p99低于2.61ms,而Elastic Search的p99则达到了10.28ms。
    在这里插入图片描述

3.6 读延迟分析

在下图中,显示了读测试吞吐量为250ops/sec时从p0到p9999的延迟百分位数:

  • Redis JSON是在所有分析的延迟百分位数中保持亚毫秒级延迟的唯一解决方案。
  • 在p99时,Redis JSON的延迟为0.23ms,其次是MongoDB的5.01ms, ElasticSearch的10.49ms。
    在这里插入图片描述

3.7 写延迟分析

在下图中,显示了写测试吞吐量为250ops/sec时从p0到p9999的延迟百分位数:

  • MongoDB和Redis JSON即使在p99时也保持着亚毫秒级的延迟。
  • Elastic Search显示出很高的尾部延迟(>10ms),很可能是由于与Elastic Search的搜索峰值相同的原因(GC)。
    在这里插入图片描述

3.8 Redis Search VS. ElasticSearch

只关注ElasticSearch和Redis JSON,同时保持6K ops/sec的可持续负载,我们可以观察到:

  • 在读和更新(写)时
    • ElasticSearch和Redis JSON(更稳定的方案)的读取和更新模式仍然跟之前250 ops/sec时的压测差不多。
    • 在读时,Redis JSON的p99为3ms,而ElasticSerach的p99为162ms。
    • 在更新时,Redis JSON的p99为3ms,而ElasticSearch的p99为167ms。
  • 在搜索时
    • Elastic Search和Redis JSON以一位数的p50延迟开始(Redis JSON的p50延迟为1.13ms,而Elastic Search的p50延迟为2.79ms)
    • 在较高的百分位数上,Elastic Search付出了GC触发和查询缓存丢失的代价,这在>= p90百分位数上可以清楚地看到。
    • Redis JSON(更高效)的p99保持在33ms以下,而在Elastic Search上,p99保持在163ms,是前者的5倍。

具体测试结果参见下图:
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

3.9 总结

测试项RedisSearchElasticSearchMongoDB结果对比
100%写吞吐量:69672/秒
平均耗时:0.341毫秒
吞吐量:7911/秒
平均耗时:7.818毫秒
吞吐量:37985/秒
平均耗时:1.001毫秒
  • Redis JSON比MongoDB快5.4倍
  • 比ElasticSearch在单独写方面快200倍
  • 99%的Redis请求在不到1.5ms的时间内完成
100%读吞吐量:178364/秒
平均耗时:0.172毫秒
吞吐量:11281/秒
平均耗时:5.578毫秒
吞吐量:62933/秒
平均耗时:0.768毫秒
  • Redis JSON比MongoDB快12.7倍
  • 比ElasticSearch快500倍
混合读/写/搜索持续更新数据并增加写入比例不会影响读取或搜索性能,反而会提高整体吞吐量(从10k到16k)。随着更新比例从0%增加到50%,吞吐量(Ops/sec)从10k下降到2.1k(降低5倍),性能受到显著影响,读取和搜索速度变慢。搜索性能比Redis JSON和ElasticSearch慢两个数量级,最大吞吐量为424 Ops/sec,而Redis JSON为16k Ops/sec。
  • Redis JSON在混合工作负载下的吞吐量比MongoDB高50.8倍,比ElasticSearch高7倍。
  • Redis JSON的操作延迟比MongoDB低91倍,比ElasticSearch低23.7倍。
  • Redis Search几乎不受更新比例影响,吞吐量稳步提升,三者中性能最高;ElasticSearch受到更新比例的显著影响,随着更新比例的提高,读取和搜索速度变慢;MongoDB性能整体最差(比RedisSearch、ElasticSearch慢2个数量级)。

优劣势对比:

  • RedisSearch 的优势在于其在所有测试项中都表现出色,具有最高的吞吐量和最低的延迟,几乎不受更新比例的影响。
  • ElasticSearch 的劣势在于其性能随着更新比例的增加显著下降,读写操作的延迟较高。
  • MongoDB 的劣势在于其整体性能最差,无论是读、写还是混合操作,吞吐量和延迟都远不及RedisSearch和ElasticSearch。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/456609.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

DSPy:不需要手写prompt啦,You Only Code Once!

论文地址:https://arxiv.org/abs/2310.03714   项目地址:https://github.com/stanfordnlp/dspy 文章目录 1. 背景2. 签名3. 模块3.1 预测模块3.2 其他内置模块 4. 提词器5. 评估目标6. 代码分析6.1 _prepare_student_and_teacher6.2 _prepare_predicto…

985研一,转嵌入式好还是后端开发好?

有个老铁问,985研一,转嵌入式好还是后端开发好? 我认为,这学历,两个随便挑,我说的,从趋势来看,更建议嵌入式,走供应链上游,芯片原厂、新能源车企、军工或者搞…

力扣143:重排链表

给定一个单链表 L 的头节点 head ,单链表 L 表示为: L0 → L1 → … → Ln - 1 → Ln请将其重新排列后变为: L0 → Ln → L1 → Ln - 1 → L2 → Ln - 2 → … 不能只是单纯的改变节点内部的值,而是需要实际的进行节点交换。 示…

qt creator 转 visual stdio 项目调试

因果 大家在使用qt creator调试程序时,会出现未知错误,比如下图,直接release运行就没有问题。由于调试复杂程序,使用qt creator都感觉不如vs,会报未知中断。 所以有了从qt creator转换到 visual stdio来调试的想法。…

【电子元件】光通量和色温 (欧司朗LED灯珠 KW3 CGLNM1.TG命名规则)

什么是光通量? 光通量(Luminous Flux)是衡量光源在单位时间内发出的可见光总量的物理量,表示的是光源产生的总光能量,其中只考虑人眼能感知的部分。它通常以流明(lumen,符号为 lm)为…

如何使用gitlab切换分支

第一步,在gitlab上新建一个远程分支。选择New branch即可新建一个,但是注意往往是在当前分支下新建的分支,所以新分支里会有当前分支的内容。 第二步,在本地当前分支在运行这三行命令,即可得到一个空的新分支。 git c…

springboot2.0x 和springboot 1.0 整合redis 使用自定义CacheManager 问题

问题描述: 在我们深入理解springboot2.0x的缓存机制的时候,发现在springboot1.0 和springboot2.0 中默认的序列化都是使用的jdk的 Serializer 实现这个接口,jdk自带的序列化方法,由此我们需要自己去创建自定义的RedisCacheManager…

《Python游戏编程入门》注-第2章2

《Python游戏编程入门》的“2.2.5 绘制线条”中提到了通过pygame库绘制线条的方法。 1 相关函数介绍 通过pygame.draw模块中的line()函数来绘制线条,该函数的格式如下所示。 line(surface, color, start_pos, end_pos, width1) -> Rect 其中,第一…

AUTOSAR CP 中 BswM 模块功能与使用介绍(2/2)

三、 AUTOSAR BswM 模块详解及 ARXML 示例 BswM 模块的主要功能 BswM(Basic Software Mode Manager)模块在 AUTOSAR 架构中扮演着模式管理的核心角色。它负责管理车辆的各种模式(如启动、运行、停车等),并根据不同的…

基于vue框架的的电子商务网站68pwt(程序+源码+数据库+调试部署+开发环境)系统界面在最后面。

系统程序文件列表 项目功能:用户,商品分类,商品信息 开题报告内容 基于Vue框架的电子商务网站开题报告 一、研究背景与意义 随着互联网技术的不断发展和普及,电子商务已成为现代商业活动的重要组成部分。电子商务网站作为线上交易的主要平台&#xf…

Apple Vision Pro市场表现分析:IDC最新数据揭示的真相

随着AR/VR技术逐渐成熟并被更多消费者接受,2024年第二季度(Q2)成为这一领域的一个重要转折点。根据国际数据公司(IDC)发布的最新报告,整个AR/VR市场在本季度经历了显著的增长。接下来,我们将深入探讨Apple Vision Pro在这股增长浪潮中的具体表现。 市场背景 2024年Q2,…

Excel:vba实现生成随机数

Sub 生成随机数字()Dim randomNumber As IntegerDim minValue As IntegerDim maxValue As Integer 设置随机数的范围(假入班级里面有43个学生,学号是从1→43)minValue 1maxValue 43 生成随机数(在1到43之间生成随机数)randomNumber Application.WorksheetFunctio…

混个1024勋章

一眨眼毕业工作已经一年了,偶然进了游戏公司成了一名初级游戏服务器开发。前两天总结的时候,本来以为自己这一年没学到多少东西,但是看看自己的博客其实也有在进步,虽然比不上博客里的众多大佬,但是回头看也算是自己的…

.net 根据html的input type=“week“控件的值获取星期一和星期日的日期

初始化 "week" 控件值: //MVC部分 public ActionResult WeeklyList() {int weekNo new GregorianCalendar().GetWeekOfYear(System.DateTime.Now, System.Globalization.CalendarWeekRule.FirstDay, DayOfWeek.Sunday);string DefaultWeek DateTime.No…

利用移动式三维扫描技术创建考古文物的彩色纹理网格【上海沪敖3D】

文章来源于蔡司工业质量解决方案,作者蔡司工业质量 在考古环境中,三维扫描技术应用广泛,如存档、保存、复制和分享(包括实体和虚拟形式)。 文中,通过真实的扫描案例,您将了解到三维光学解决方案…

JavaWeb 23.一文速通npm的配置和使用

目录 一、npm的介绍 二、npm的安装和配置 1.安装 : 2.配置依赖下载使用阿里镜像 3. 配置全局依赖下载后存储位置 4.升级npm版本 5.环境变量配置 三、npm常用命令 1.项目初始化 npm.init npm init -y 2.安装依赖文件 3. 升级依赖 4.卸载依赖 5.查看依赖 查看项目…

Android 原生开发与Harmony原生开发浅析

Android系统 基于Linux ,架构如下 底层 (Linux )> Native ( C层) > FrameWork层 (SystemService) > 系统应用 (闹钟/日历等) 从Android发版1.0开始到现在15,经历了大大小小的变革 从Android6.0以下是个分水岭,6.0之前权限都是直接卸载Manifest中配置 6.0开始 则分普…

Rust的move关键字在线程中的使用

为什么使用 move? 在 Rust 中,move 关键字主要用于闭包。当我们在一个线程中创建一个闭包并将其传递给另一个线程时,如果闭包中使用了某些变量,就需要决定这些变量的所有权归属。 不使用 move: 默认情况下&#xff0…

LabVIEW提高开发效率技巧----事件日志记录

在LabVIEW开发中,集成事件日志记录系统是提升程序调试效率和确保系统运行稳定的关键步骤。通过记录关键操作和异常事件,开发人员可以快速定位问题、优化程序性能,并确保系统的稳定性和可靠性。 1. 事件日志的作用 事件日志是指在程序运行过…

python-PyQt项目实战案例:制作一个视频播放器

文章目录 1. 关键问题描述2. 通过OpenCV读取视频/打开摄像头抓取视频3. 通过PyQt 中的 QTimer定时器实现视频播放4. PyQt 视频播放器实现代码参考文献 1. 关键问题描述 在前面的文章中已经分享了pyqt制作图像处理工具的文章,也知道pyqt通过使用label控件显示图像的…