前言

今天给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的更多相关文章

  1. SuperBenchmarker一个用.NET编写的压测工具

    0x01 前言 在这之前想必大家对ab(http)与abs(https)也有一些了解,我们今天不去看ab和abs,SuperBenchmarker(sb.exe)是一个压测工具,他是一个受Apache ...

  2. Apache自带 ab压测工具 Windows配置使用说明 - 随笔记录

    我们先来了解一下ab工具的概念,摘自网络: ab是apache自带的压力测试工具.ab非常实用,它不仅可以对apache服务器进行网站访问压力测试,也可以对或其它类型的服务器进行压力测试.比如ngin ...

  3. python服务端多进程压测工具

    本文描述一个python实现的多进程压测工具,这个压测工具的特点如下: 多进程 在大多数情况下,压测一般适用于IO密集型场景(如访问接口并等待返回),在这种场景下多线程多进程的区分并不明显(详情请参见 ...

  4. 作业2:go实现一个压测工具,具备upload功能

    作业:go实现压测工具,具备upload功能. upload内容是.tar.gz,使用http协议上传. 要求:upload的文件名,http目的地址灵活可配. deadline:2019.4.30

  5. Http压测工具wrk使用指南

    用过了很多压测工具,却一直没找到中意的那款.最近试了wrk感觉不错,写下这份使用指南给自己备忘用,如果能帮到你,那也很好. 安装 wrk支持大多数类UNIX系统,不支持windows.需要操作系统支持 ...

  6. Http压测工具wrk使用指南【转】

    用过了很多压测工具,却一直没找到中意的那款.最近试了wrk感觉不错,写下这份使用指南给自己备忘用,如果能帮到你,那也很好. 安装 wrk支持大多数类UNIX系统,不支持windows.需要操作系统支持 ...

  7. Http 压测工具 wrk 基本使用

    Http 压测工具 wrk 基本使用 Intro wrk 是一款现代HTTP基准测试工具,能够在单个多核CPU上运行时产生显着负载.它将多线程设计与可扩展事件通知系统(如epoll和kqueue)结合 ...

  8. wrk压测工具使用

    介绍分为四部分 1.wrk简述 2.wrk安装 3.wrk运行参数 4.wrk高级用法 1.wrk简述 当使用ab做压测的时候发现,ab的客户端消耗很大,而且测试时性能较差,测试redis,sprin ...

  9. web服务器压测工具siege、ab

    web服务器压测工具也挺多,这里只介绍我用过的这两种--siege(for linux).ab(for windows). 一.siege 1.简介: Siege是一款开源的压力测试工具,设计用于评估 ...

  10. 问题追查:QA压测工具http长连接总是被服务端close情况

    1. 背景 最近QA对线上单模块进行压测(非全链路压测),http客户端 与 thrift服务端的tcp链接总在一段时间被close. 查看服务端日志显示 i/o timeout. 最后的结果是: q ...

随机推荐

  1. SQL Sever 各版本的适用环境

    很多用visual studio做开发的朋友经常会用到sqlserver数据库,但是往往在选择的时候就不知道该使用哪个版本了,今天就给大家分享一下sqlserver各个版本之间的区别,以及各个版本之间 ...

  2. 【java-Err】 Generating equals/hashCode implementation but without a call to superclass,

    @EqualsAndHashCode  默认不继承父类 修复此问题的方法很简单:  1. 使用@Getter @Setter @ToString代替@Data并且自定义equals(Object ot ...

  3. iOS CoreData总结

    相关主要类: NSManagedObjectContext 管理对象,上下文,持久性存储模型对象,处理数据与应用的交互 NSManagedObjectModel 被管理的数据模型,数据结构 NSPer ...

  4. Centos安装ELK

    目录 安装Elastic Search 安装 Java 安装Elastic Search 修改配置 开放端口 访问地址 相关命令 安装elasticsearch-head插件 安装Git 安装node ...

  5. 【转载】Linux虚拟化KVM-Qemu分析(三)之KVM源码(1)

    原文信息: 作者:LoyenWang 出处:https://www.cnblogs.com/LoyenWang/ 公众号:LoyenWang 版权:本文版权归作者和博客园共有 转载:欢迎转载,但未经作 ...

  6. Hugging News #0717: 开源大模型榜单更新、音频 Transformers 课程完成发布!

    每一周,我们的同事都会向社区的成员们发布一些关于 Hugging Face 相关的更新,包括我们的产品和平台更新.社区活动.学习资源和内容更新.开源库和模型更新等,我们将其称之为「Hugging Ne ...

  7. 轻松理解Java中的public、private、static和final

    一.概念 1.public和private 两个都是访问权限修饰符,用于控制外界对类内部成员的访问. public:表明对象成员是完全共有的,外界可以随意访问.用public修饰的数据成员.成员函数是 ...

  8. C# Task 实现任务超时取消、超时取消然后重试 超过重试最大次数就结束。

    任务超时取消 示例 public static async Task TimeoutCancelTask() { CancellationTokenSource cts = new Cancellat ...

  9. 利用文件包含漏洞包含ssh日志拿shell

    今天看文章学了一招,有包含漏洞无法传文件的时候用 目标服务器环境为ubuntu,ssh登录日志文件是/var/log/auth.log 找个Linux的环境执行ssh '<? phpinfo() ...

  10. linux 查找目录中的大文件

    find是Linux系统中常用的文件查找命令.它可以在文件系统中查找指定条件的文件,并执行相应的操作.语法格式如下: find [pathname] [options] pathname: 指定查找的 ...