分享一个Redis自带的压测工具:redis-benchmark
前言
今天给xdm分享一个Redis自带的压测工具:redis-benchmark
。
介绍
redis-benchmark
是一个用于测试 Redis性能的基准测试工具,可以帮助开发人员评估和比较 Redis 在不同配置或负载情况下的吞吐量和延迟。
使用 redis-benchmark
可以执行多种类型的基准测试,例如:
- SET/GET 操作测试:通过执行 SET 和 GET 命令来测试 Redis 的读写性能。
- 并发连接测试:模拟多个并发连接同时执行 Redis 操作,测试 Redis 在高并发环境下的性能表现。
- 多线程测试:通过在多个线程中执行 Redis 操作来测试 Redis 在多线程环境下的性能表现。
- 数据大小测试:通过测试不同数据大小的操作来评估 Redis 在处理不同数据量时的性能表现。
redis-benchmark
提供了丰富的配置选项,可以控制并发连接数、数据大小、执行命令的类型等。测试结果包括每秒执行的命令数、平均延迟等指标,可以帮助开发人员优化 Redis 配置和应用程序设计,获得更好的性能。
示例
1、启用100个并发,发100000个请求。
redis-benchmark -h 127.0.0.1 -p 6379 -c 100 -n 100000
-h 127.0.0.1
:指定 Redis 服务器的主机地址为 127.0.0.1,即本地主机。-p 6379
:指定 Redis 服务器的端口号为 6379,默认情况下 Redis 使用 6379 端口。-c 100
:指定并发连接数为 100,即同时并发地执行操作。-n 100000
:指定执行操作的总次数为 100,000 次。
如图所示,1.27秒就完成了100000次请求,每秒78802的吞吐量,说明Redis本身的性能就非常好。
这是最常用的命令,可以评估 Redis 在指定条件下的并发处理能力和性能表现。
2、指定主机地址、端口号和数据库编号测试Redis实例的性能
redis-benchmark -h 127.0.0.1 -p 6379 -q -d 100
-h 127.0.0.1
:指定 Redis 服务器的主机地址为 127.0.0.1,即本地主机。-p 6379
:指定 Redis 服务器的端口号为 6379,默认情况下 Redis 使用 6379 端口。-q
:指定以静默模式运行基准测试,只输出总结结果,不显示每个操作的详细信息。-d 100
:指定要测试的数据库编号为 100。默认情况下 Redis 使用 0 号数据库。
如图所示,每秒的qps是7万多,性能很高。
3、执行100,000次测试 SET 和 LPUSH 命令的性能
redis-benchmark -t set,lpush -q -n 100000
4、执行100,000次测试Lua脚本的性能
redis-benchmark -n 100000 -q script load "redis.call('set','foo','bar')"
-t set,lpush
:指定要执行的命令类型。在本例中,将同时执行SET
和LPUSH
命令,即将键值对设置到 Redis 中,并将元素推入列表。-q
:指定以静默模式运行基准测试,只输出总结结果,不显示每个操作的详细信息。-n 100000
:指定执行操作的总次数为 100,000 次。
-n 100000
:指定执行操作的总次数为 100,000 次。在本例中,将执行 100,000 次script load
命令。-q
:指定以静默模式运行基准测试,只输出总结结果,不显示每个操作的详细信息。script load "redis.call('set','foo','bar')"
:指定要执行的命令内容。在本例中,将执行script load
命令,并将 Lua 脚本作为参数传递给该命令。脚本内容是redis.call('set','foo','bar')
,表示在 Redis 中执行SET
命令来设置键名为foo
、值为bar
的键值对。
总结
通过 redis-benchmark
的测试结果,你可以获得qps、平均延迟、错误率等性能指标,从而根据需要进行调优和优化,确保Redis在实际生产环境中具有良好的性能和可靠性。
好了,今天的小知识你学会了吗?
如果喜欢,请点赞+关注↓↓↓,持续分享干货哦!
分享一个Redis自带的压测工具:redis-benchmark的更多相关文章
- SuperBenchmarker一个用.NET编写的压测工具
0x01 前言 在这之前想必大家对ab(http)与abs(https)也有一些了解,我们今天不去看ab和abs,SuperBenchmarker(sb.exe)是一个压测工具,他是一个受Apache ...
- Apache自带 ab压测工具 Windows配置使用说明 - 随笔记录
我们先来了解一下ab工具的概念,摘自网络: ab是apache自带的压力测试工具.ab非常实用,它不仅可以对apache服务器进行网站访问压力测试,也可以对或其它类型的服务器进行压力测试.比如ngin ...
- python服务端多进程压测工具
本文描述一个python实现的多进程压测工具,这个压测工具的特点如下: 多进程 在大多数情况下,压测一般适用于IO密集型场景(如访问接口并等待返回),在这种场景下多线程多进程的区分并不明显(详情请参见 ...
- 作业2:go实现一个压测工具,具备upload功能
作业:go实现压测工具,具备upload功能. upload内容是.tar.gz,使用http协议上传. 要求:upload的文件名,http目的地址灵活可配. deadline:2019.4.30
- Http压测工具wrk使用指南
用过了很多压测工具,却一直没找到中意的那款.最近试了wrk感觉不错,写下这份使用指南给自己备忘用,如果能帮到你,那也很好. 安装 wrk支持大多数类UNIX系统,不支持windows.需要操作系统支持 ...
- Http压测工具wrk使用指南【转】
用过了很多压测工具,却一直没找到中意的那款.最近试了wrk感觉不错,写下这份使用指南给自己备忘用,如果能帮到你,那也很好. 安装 wrk支持大多数类UNIX系统,不支持windows.需要操作系统支持 ...
- Http 压测工具 wrk 基本使用
Http 压测工具 wrk 基本使用 Intro wrk 是一款现代HTTP基准测试工具,能够在单个多核CPU上运行时产生显着负载.它将多线程设计与可扩展事件通知系统(如epoll和kqueue)结合 ...
- wrk压测工具使用
介绍分为四部分 1.wrk简述 2.wrk安装 3.wrk运行参数 4.wrk高级用法 1.wrk简述 当使用ab做压测的时候发现,ab的客户端消耗很大,而且测试时性能较差,测试redis,sprin ...
- web服务器压测工具siege、ab
web服务器压测工具也挺多,这里只介绍我用过的这两种--siege(for linux).ab(for windows). 一.siege 1.简介: Siege是一款开源的压力测试工具,设计用于评估 ...
- 问题追查:QA压测工具http长连接总是被服务端close情况
1. 背景 最近QA对线上单模块进行压测(非全链路压测),http客户端 与 thrift服务端的tcp链接总在一段时间被close. 查看服务端日志显示 i/o timeout. 最后的结果是: q ...
随机推荐
- SSM项目整合思路以及代码
当前真实的企业开发中,SpringBoot已经统一Java企业应用开发,很少有在使用SSM项目来进行项目开发的. 可是在教学阶段,还是很有必要给学生讲解Java开发中一套很经典的框架,SSM框架.作为 ...
- 浅析synchronized锁升级的原理与实现
背景 在多线程编程中,线程同步是一个关键的概念,它确保了多个线程对共享资源的安全访问.Java中的synchronized关键字是一种常用的线程同步机制,它不仅提供了互斥访问的功能,还具备锁升级的特性 ...
- happens-before 原则
happens-before 简述 从 JDK 5 开始,Java 使用新的 JSR-133 内存模型.JSR-133 使用 happens-before 的概念来阐述操作之间的内存可见性.在 JMM ...
- SPI总线学习笔记
SPI是串行外设接口(Serial Peripheral Interface)的缩写,是一种高速的,全双工,同步的通信总线,并且在芯片的管脚上只占用四根线,节约了芯片的管脚,同时为PCB的布局上节省空 ...
- 2021-11-17 WPF初识
StackPanel容器:默认竖直排列,Orientation="Horizontal"横向排列,超过就不会显示 wrapPanel:超过会自动换行 设置样式: <Windo ...
- Node: 将时间戳转换成日期并分组
// 对时间戳按日期进行分组 let moment = require('moment') let timestamp_array = [ 1645059333000, 1613523333000, ...
- 基于inotify-tools和rsync实现文件实时同步
前言 系统:centos 7 inotify-tools版本:3.14(3.22版本测试有问题,所以找的比较旧的一版) 主机IP: 192.168.137.7(服务端,接收同步文件) 192.168. ...
- Electron-builder打包和自动更新
Electron-builder打包和自动更新 前言 文本主要讲述如何为 electron 打包出来软件配置安装引导和结合 github 的 release 配置自动更新. electron-buil ...
- C++函数参数匹配规则
C++ 函数参数匹配 1 单个参数匹配 void f(); //f1 void f(int); //f2 void f(int, int); //f3 void f(double, double=3. ...
- SpringBoot3集成Kafka
目录 一.简介 二.环境搭建 1.Kafka部署 2.Kafka测试 3.可视化工具 三.工程搭建 1.工程结构 2.依赖管理 3.配置文件 四.基础用法 1.消息生产 2.消息消费 五.参考源码 标 ...