缓存怎么测试?

2023-11-02

1、缓存的介绍

平时用的Redis缓存是一款高性能的内存型键值对(key-value)数据库,是高并发场景常用一款存储中间件,其主要用于:缓存热点数据,减少DB的请求IO

其场景使用主要有:分布式锁,全局ID,计数器,限流,消息队列,购物车等

2、缓存的使用

Redis存储键值对,支持5种数据类型,String, HashList,SetZset,缓存一般和DB配合使用,其缓存与DB的交互:

PS 部分场景可能存在查询缓存时,如缓存无数据,可能会直接返回空数据给客户端,不再去查询DB

3、缓存的设计

4、缓存的测试

PS: 缓存的测试可从四个唯度进行测试:

 

使用场景评审

1 缓存使用场景的评审:

  • 评估业务场景是否真的需要缓存;

2 评估缓存 DB 短期的数据短期暂不致对业务带来的影响;

3 键值规范设计是否合理:

  • 请考 缓存设计 KEY-VALU的规范

4 业务场景中缓存模式的选择:

参考 缓存模式的选择

5 缓存的更新策略:

  • 是否存在并发场景,是否在并发场景下出现脏数据的读
  • 参考缓存的更新策略,一般推荐先更新DB,再淘汰缓存

6 业务使用的空间大小是否在最近的增长时有内存不够风险:

7 评估缓存时间设置的合理性;

缓存的功能测试

 

缓存的特殊场景

1 缓存超时:

验证缓存查询达到超时后,未返回指定的数据,对系统的影响;强弱依赖

2 缓存穿透

不断查询一个DB和缓存中一定不存在的数据,验证返回数据为空;

3 缓存雪崩:

验证缓存 是否采用了相同的过期时间,如果缓存 大量在同一时间失效,验证系统功能是否正常,DBIO读取是否正常,其系统中DB性能指标是否正常;

4 缓存击穿:

缓存中的数据没有查询过,第一次高并发访问

缓存中的一条数据刚好失效,进行高并发访问 ,校验功能是否正常,DB指标是否正常,其对应的性能指标是否正常;

5 缓存预热:

大批量缓存在同一时间点过期,验证缓存预热耗时及预期时机

在缓存预期期间请求 更新接口和查询接口,验证返回数据的正确性

6 缓存内存上限:

验证缓存淘汰参数配置与预期是否一致:增加缓存到达最大内存限制时(通过修改redis.conf配置文件中配置最大可用内存值maxmemory),再次请求查询 ,数据返回是否正确,且缓存淘汰是否正确

7 缓存服务异常

验证关闭缓存服务,系统功能和性能的表现

重启缓存,请求查询数据是否正确,DB数据与Redis数据是否一致;

6 读写并发测试:

并发请求缓存中的有的数据,验证返回数据是否正确,性能指标是否正常

并发请求缓存中没有但DB有的数据,验证返回数据是否正确,性能指标是否正常

并发请求缓存中和DB中也没有的数据,验证返回数据是否为空,性能指标是否正常;

7 性能测试(redis-benchmark)

单机和集群Reids的吞吐量

对比不同存储类型的性

开启和关闭持久化的吞吐量

对比调优前后的吞吐量

对比不同版本的Redis的吞吐量

缓存 的监控

缓存的命中率,评估缓存设计 是否达到预期

监控CPU,内存使用率,及 CPU,内存使用异常

监控Key值过大的阀值

监控KEY是否存在频繁更新场景

监控Value读取时间

 

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

缓存怎么测试? 的相关文章

随机推荐

  • 软件产品设计的学习总结

    一个成功的软件产品通常需要包含以下几个方面 可靠性 软件产品需要稳定可靠 能够正确地运行 并且在用户使用中没有频繁崩溃或者其他问题 安全性 软件产品在使用过程中需要保证数据的安全性 包括用户的个人和商业隐私等方面 易用性 软件产品需要具有高
  • JAVA中的高并发,解决高并发的方案

    java高并发 如何解决 什么方式解决 一 什么是高并发 二 高并发的解决方法有两种 三 追加 一 什么是高并发 1 1 高并发 High Concurrency 是互联网分布式系统架构设计中必须考虑的因素之一 它通常是指 通过设计保证系统
  • 实现spawn-fcgi的守护监控功能

    http blog csdn net cleanfield article details 6409830 这几天做公司平台的api部分 决定采用c c 版本的fcgi 于是采用了spawn fcgi作为启动框架 不过遇到个问题就是spaw
  • matlab练习程序(神经网络识别mnist手写数据集)

    记得上次练习了神经网络分类 不过当时应该有些地方写的还是不对 这次用神经网络识别mnist手写数据集 主要参考了深度学习工具包的一些代码 mnist数据集训练数据一共有28 28 60000个像素 标签有60000个 测试数据一共有28 2
  • 苹果Swift语言入门教程

    目录 1 简介 2 Swift入门 3 简单值 4 控制流 5 函数与闭包 6 对象与类 7 枚举与结构 1 简介 今天凌晨Apple刚刚发布了Swift编程语言 本文从其发布的书籍 The Swift Programming Langua
  • python三引号作用是什么_python中三引号的作用(逗号的两点总结)

    三引号 1 三引号注释 程序中我使用 来做单行注释 可以使用三引号可以做多行注释 三个引号能包含多行字符串 同时常常出现在函数的声明的下一行 来注释函数的功能 与众不同的地方在于 这个注释作为函数的一个默认属性 可以通过 函数名 doc 来
  • 相信AI的力量——「AI中国」2021年度十大开源事件揭晓

    自2017 年设立以来 机器之心 Synced Machine Intelligence Awards 年度奖项评选活动自已连续举办至第五届 是目前国内人工智能界规模最大 评选最权威的年度奖项 已成为我国人工智能产业的风向标 2021年底
  • Visual Studio 和 Visual Studio Code的区别?

    Visual Studio 是一个全能的 方便的开发环境 即 IDE 像代码自动完成 调试器 数据库集成 服务器设置和配置等 Visual Studio Code VSCode 只是一个跨平台的编辑器 但是用户可以根据自己的需求去增加插件
  • cmath(常用函数)

    cmath包含了许多数学函数 非常实用 1 三角函数 double sin double 正弦 double cos double 余弦 double tan double 正切 2 反三角函数 double asin double 结果介
  • 上MES系统的目的是什么?

    上MES系统的目的是什么 实现透明制造 柔性制造 精益制造 创新制造 观点 太空洞 太空洞 太空洞 开发者的观点 计划 质量 生产 物流一体化管理 要接地气 客户说aps需要 前台傻瓜 后台智能 操作APS的起码有点水准的人吧 太傻瓜能操作
  • pt_session流程

    pt 即 prime time 数字IC后端设计人员用于check pr之后的path timing 的重要工具 在从后端拿到pt session的前提下 确认sdc或者cdc sdc是否有语法问题等 完成脚本的快速迭代 确保前端交付质量
  • vue前端实现打印功能

    方案一 window print 这个命令默认打印整个页面的内容 所以 如果想要实现局部打印功能的话 就要重新给body赋值 并且后续执行完之后再还原回去 这样的话会造成一些非预期的结果 很麻烦 并且在当前也操作 window docume
  • 剪映VS会声会影哪个好用,视频剪辑软件剪映会声会影之间对比之

    随着网络视频的发展 越来越多的人开始学习视频剪辑 毕竟技多不压身 而在众多剪辑软件中 剪映和会声会影是很适合新手使用的软件 那剪映与会声会影的区别有哪些 剪映会声会影哪个好用 下面就仔细说说 一 剪映与会声会影的区别 在剪辑功能上 剪映和会
  • 武装突袭3fps服务器不稳定,《武装突袭3》深不见底:史上最硬核、最复杂的FPS游戏...

    武装突袭3 深不见底 史上最硬核 最复杂的FPS游戏武装突袭3是一个硬核的而且复杂的游戏 我玩了一千六百多个小时 但依然没有玩透它 如果用一个词来形容ARMA3那么就是深不见底 大多数人在这里只能在某一个领域成为专家 所以如果你准备入手武装
  • gensim中TaggedDocument 怎么使用

    我有两个目录 我想从中读取它们的文本文件并给它们贴上标签 但我不知道如何通过taggedDocument来实现这一点 我以为它可以作为标记文档 strings labels 工作 但这显然不起作用 from gensim import mo
  • 超级账本PBFT(拜占庭容错)算法详解

    上一章我们从分布式系统的角度简单叙述了一下 IBM HyperLedger fabric 的一些基本概念 架构和协议信息 其中最为核心的部分就是共识算法 consensus plugin fabric推荐并实现的就是PBFT这一经典算法 B
  • 弱监督学习--半监督学习(3):Mean teachers are better role models

    前言 论文链接 https arxiv org pdf 1703 01780 pdf github https github com CuriousAI mean teacher Mean Teacher 模型是由芬兰的一家AI初创公司在2
  • c语言怎样的序列满足堆,C语言堆排序法谁能通俗易懂又清晰地讲解一下?谢谢...

    您可以找本数据结构的书看看 比如清华严尉敏的 数据结构 以下摘抄于 http student zjzk cn course ware data structure web paixu paixu8 4 2 1 htm 这个网站的讲解挺不错
  • Android OpenGL ES2.0(一):详细讲解如何绘制一个三角形

    一 Android OpenGL ES2 0简介 1 什么是OpenGL OpenGL 全写Open Graphics Library 是指定义了一个跨编程语言 跨平台的编程接口规格的专业的图形程序接口 它用于三维图像 二维的亦可 是一个功
  • 缓存怎么测试?

    1 缓存的介绍 平时用的Redis缓存是一款高性能的内存型键值对 key value 数据库 是高并发场景常用一款存储中间件 其主要用于 缓存热点数据 减少DB的请求IO 其场景使用主要有 分布式锁 全局ID 计数器 限流 消息队列 购物车