Redis集群中怎么做性能基准测试_针对特定版本分析集群的QPS上限
从现在开始,努力学习吧!本文《Redis集群中怎么做性能基准测试_针对特定版本分析集群的QPS上限》主要讲解了等等相关知识点,我会在golang学习网中持续更新相关的系列文章,欢迎大家关注并积极留言建议。下面就先一起来看一下本篇正文内容吧,希望能帮到你!
Redis 6.2+需用--cluster参数运行redis-benchmark,否则MOVED/ASK重定向导致QPS归零;低版本需手动固定槽位或升级。

用 redis-benchmark 测集群 QPS,但得绕过重定向陷阱
直接对集群任意节点跑 redis-benchmark -h 127.0.0.1 -p 7000 -n 100000 会失败,因为集群模式下多数命令(如 SET、GET)触发 MOVED 或 ASK 重定向,而 redis-benchmark 默认不处理——它把重定向响应当成错误,QPS 统计崩掉,甚至返回 0。
必须加 -c(客户端连接数)和 -t(指定命令),更重要的是:用 --cluster 模式(Redis 6.2+)或退而求其次,让 benchmark 打到一个稳定槽位上:
- 如果 Redis 版本 ≥ 6.2,用
redis-benchmark -h 127.0.0.1 -p 7000 --cluster -n 100000 -t set,get,它会自动解析集群拓扑并打散请求 - 若版本 {user1001} 这种带哈希标签的 key,确保所有请求落到同一分片,再配合
-r随机生成(如-r 1000)避免单 key 热点 - 别用
-q(quiet 模式)就完事,先加-d 64控制 value 大小,否则默认 2MB 的 payload 会压垮网络或触发 TCP 分包,测出来不是 Redis 瓶颈而是网卡瓶颈
从 INFO 实时抓取 total_commands_processed 算真实 QPS
benchmark 工具容易受客户端机器性能干扰(比如并发连接数打太高,本地 CPU 先打满),更稳的方式是直接看服务端指标。Redis 集群每个节点都暴露 INFO 接口,其中 total_commands_processed 是累计值,差值除以时间就是实际 QPS。
操作步骤很简单:
- 在测试开始前,对所有 master 节点分别执行
redis-cli -h 127.0.0.1 -p 7000 INFO | grep total_commands_processed,记下初始值 - 跑 30 秒压力(比如用 Python 脚本发请求,或
redis-benchmark -n 3000000),期间不要做其他操作 - 测试结束后立刻再抓一次
total_commands_processed,用差值 ÷ 30 得到该节点 QPS;把所有 master 节点的 QPS 加起来,才是集群总吞吐 - 注意:slave 节点的
total_commands_processed只统计自己收到的 replication stream 命令,不能计入——只看 master
redis-benchmark 的 -P 参数对集群无效,别白调
-P(pipeline 数量)在单实例上能显著提升 QPS,因为减少了 RTT;但在集群里,只要 key 不在同一个 slot,pipeline 就会被拆成多个 TCP 请求转发,效果大打折扣,甚至因跨节点协调反而变慢。
实测中常见误区:
- 设
-P 16后发现 QPS 比-P 1还低——大概率是 pipeline 里混了不同 hash tag 的 key,导致请求被路由到多个节点,协调开销盖过了 pipeline 收益 - 如果真要用 pipeline,必须保证整批 key 都落在同一 slot(例如全用
{order}1001、{order}1002),否则不如不用 - 集群场景下,优先靠增加 client 并发数(
-c)和分散 key 槽位来横向扩展,而不是堆-P
版本差异直接影响上限:6.0 vs 7.0 的多线程 I/O 表现
Redis 6.0 引入多线程 I/O(由 io-threads 和 io-threads-do-reads 控制),但仅负责 socket 读写,命令执行仍是单线程;到了 7.0,I/O 线程可真正参与部分命令预处理(如协议解析),高并发小包场景下吞吐提升约 15%~25%。
关键配置项必须匹配版本:
- Redis 6.0:设
io-threads 4后,必须设io-threads-do-reads yes,否则线程只干写,读仍卡主线程 - Redis 7.0:
io-threads-do-reads默认为 yes,且支持io-threads 8(6.0 最高建议 4),但要注意线程数 ≠ CPU 核数,超过会造成上下文切换反拖慢 - 集群环境下,每个节点都要单独配,且所有 master 节点配置应一致,否则负载不均——比如有的节点开 4 线程,有的没开,QPS 分布会严重倾斜
真正卡集群上限的,往往不是 Redis 自身,而是客户端连接池耗尽、TCP TIME_WAIT 堆积、或某个 master 节点内存碎片率 > 1.5 导致分配变慢——这些细节比“理论最大 QPS”更值得盯紧。
文中关于的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《Redis集群中怎么做性能基准测试_针对特定版本分析集群的QPS上限》文章吧,也可关注golang学习网公众号了解相关技术文章。
CSS如何解决移动端长按文字选中的困扰_使用user-select禁止选择
- 上一篇
- CSS如何解决移动端长按文字选中的困扰_使用user-select禁止选择
- 下一篇
- Python Pyecharts怎么用_生成酷炫交互式HTML网页图表
-
- 数据库 · Redis | 1天前 | Redis · Streams · 消费者组 · Pending · XACK · 消息堆积 消费者组 XACK XPENDING XAUTOCLAIM Redis Streams
- Redis Streams 消费者组消息堆积怎么办:从 XPENDING 到 XACK 一步步排查
- 385浏览 收藏
-
- 数据库 · Redis | 3天前 | Redis · 数据库 · HyperLogLog · UV统计 · redis hyperloglog UV统计 PFADD PFCOUNT 去重计数
- Redis HyperLogLog 统计 UV 实战:PFADD、PFCOUNT 和误差边界怎么用
- 180浏览 收藏
-
- 数据库 · Redis | 3天前 | Redis · 消息队列 · Stream · 消费组 · redis 消息队列 Redis Stream 消费组 XREADGROUP XACK XPENDING XAUTOCLAIM
- Redis Stream 消息队列实战:消费组、ACK 和失败重投怎么配
- 187浏览 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 485次学习
-
- ljg-skills
- ljg-skills 是李继刚开源的 AI 技能与提示词集合,面向大模型使用者整理了一批可复用的 prompt、角色设定和任务技能模板,适合用于学习提示词设计、搭建个人 AI 工作流和沉淀团队常用智能体能力。
- 210次使用
-
- MELO音乐
- MELO音乐是一站式AI视频与音乐制作助手,对标suno, udio的高品质体验。提供伴奏生成、原创写词、无损导出、哼唱识曲、混音变声等全套音频与短视频编辑工具。无论是流行Kpop、电音说唱、民谣古风、摇滚儿歌还是商用轻音乐,MELO为你免费谱曲,轻松做同款!
- 232次使用
-
- UniScribe
- UniScribe 是一款 AI 音视频转文字与内容整理工具,支持上传音频、视频文件或粘贴 YouTube 链接,自动生成转写文本、摘要、思维导图和关键问题,并支持多格式导出,适合会议记录、课程学习、访谈整理和内容创作复盘。
- 202次使用
-
- 剧云
- 剧云是专业中文剧本创作平台,安全稳定运行十余年,集成AI编剧、剧本医生审核、人物小传、剧情关系图、大纲编写、多人协作、Word导入导出、版权管控功能,数据安全防护,轻松高效创作剧本。
- 368次使用
-
- 万象有声
- 万象有声,一个专为有声创作者打造的新一代智能有声内容创作平台。平台提供专业的智能拆章、智能画本编辑、AI配音、AI生成音效、后期制作、智能对轨、智能审听等有声创作全流程工具,可以帮助创作者高效、低成本创作出引人入胜的有声作品。立即体验,让有声书制作更简单!
- 365次使用
-
- redis复制有可能碰到的问题汇总
- 2023-01-01 501浏览
-
- 使用lua+redis解决发多张券的并发问题
- 2023-01-27 501浏览
-
- Redis应用实例分享:社交媒体平台设计
- 2023-06-21 501浏览
-
- 使用Python和Redis构建日志分析系统:如何实时监控系统运行状况
- 2023-08-08 501浏览
-
- 如何利用Redis和Python实现消息队列功能
- 2023-08-16 501浏览

