缓存怎么测试?

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.lang.NoClassDefFoundError: javax/ws/rs/core/Configuration

    我正在实现轻松的网络服务 并且正在使用 jboss 4 0 但我遇到以下异常 java lang NoClassDefFoundError javax ws rs core Configuration 我的 web xml 是
  • 春天。使用java配置解决循环依赖而不使用@Autowired

    我有循环依赖和java配置 虽然使用 xml 配置解决它非常简单 但如果没有 Autowired 我无法使用 java 配置解决它 豆子 public class A private B b public B getB return b p
  • Maven 配置文件相当于 Gradle

    我试图在我的 spring boot 项目构建中实现一个简单的场景 包括 排除依赖项以及根据环境打包 war 或 jar 例如 对于环境dev包括开发工具和包 jar 用于prod包战等 我知道它不再是基于 XML 的配置 我基本上可以在
  • 如何解析比 Java 中 NumberFormat 更严格的数字?

    我正在验证表单中的用户输入 我解析输入NumberFormat http docs oracle com javase 7 docs api java text NumberFormat html 但它是邪恶的 几乎允许任何事情 有没有办法
  • 如何使用 Apache Camel 路由从授权服务器获取访问令牌?

    我有一个授权服务器 带有注释的简单类 SpringBootApplication RestController Configuration EnableAuthorizationServer oauth2 security 在端口上运行80
  • Spring 可以理解 @Inject 替换 Weld 作为 JSR-299 实现吗?

    我从几个网页中注意到 Spring 3 0 显然支持来自 JSR 330 的 Inject 由于我们确实希望在 Web 应用程序和独立应用程序的库中使用 JSR 299 语法进行依赖项注入 并且有 Weld 的替代方案 因此如果 Sprin
  • Android 背景 + 文本 + 按钮图标

    我想要一个图像设置为文本的背景 并在文本的左侧设置一个图标 在iPhone中非常简单 但不知道如何在Android上做到这一点 调整按钮的大小并保持图标 文本的位置和距离正确 iPhone 安卓我有这个 xml代码是
  • com.google.gwt.dev.jjs.InternalCompilerException:访问期间出现意外错误

    我在使用版本 2 6 0 编译 gwt 应用程序时遇到以下错误 最初我用 gwt 版本 2 6 1 的 maven 编译它 然后尝试通过版本 2 6 0 的 eclipse 编译它 跟版本兼容有关系吗 com google gwt dev
  • UiBinder 中的 gwt 按钮

    我需要创建一个按钮 所以它是一个带有图像的按钮 gwt with UiBinder 但我不确定如何进行 这是我的ui xml code
  • Hibernate HQL 查询:如何将集合设置为查询的命名参数?

    给定以下 HQL 查询 FROM Foo WHERE Id id AND Bar IN barList I set id使用查询对象的setInteger 方法 我想设置 barList用一个List对象 但查看 Hibernate 文档和
  • Maven:缺少工件 org.springframework:spring:jar:4.2.6

    我在 SpringToolSuite 中有一个动态 Web 项目 它被转换为 Maven 项目 我遇到问题 缺少工件 org springframework spring jar 4 2 6 我已经尝试清理 重建和运行该项目 它给 读取文件
  • 用dagger 2查看依赖注入

    我有一个自定义视图扩展TextView 我应该在哪里调用我的组件来注入视图 component inject customTextView 因此 我发现我需要在自定义视图的构造函数中添加注入 在所有视图中 或者使一个调用另一个 Exampl
  • 摆动刷新周期

    我试图了解何时使用重新验证 重绘 打包 令人惊讶的是 我没有找到详细的底层文档 请随意链接 到目前为止我已经明白这都是 RepaintManager 的责任 油漆 重新油漆指的是脏 干净的东西 pack validate revalidat
  • 如何告诉 Java SAX 解析器忽略无效字符引用?

    当尝试使用字符引用解析不正确的 XML 时 例如 x1 Java 的 SAX 解析器因致命错误而惨死 例如 org xml sax SAXParseException Character reference x1 is an invalid
  • 使用JPanel绘制直线并获取点坐标

    我现在完全不知所措 我没有太多用 Java 构建 GUI 我一直在阅读有关 swing 和 JPanel 的所有内容 我认为我想做的事情是可能的 我只是还没有弄清楚how 我正在尝试构建一个 GUI 您可以在其中在某个绘图区域内绘制直线 我
  • 如何在其他窗口之上生成独立的 JFileChooser 对话框?

    Like 其他一些人 https stackoverflow com questions 4161207 javavm windows 7 64bit jfilechooser not showing dialog box谁问过类似的问题
  • Java可以进行进程监控吗?

    是否可以用Java编写一个在托盘中运行的应用程序 并且当启动某个应用程序时 它可以检测到它 我想对某些程序执行此操作 以了解我每周使用它们多长时间 我是 Java 新手 所以我不知道 Java 是否是最适合此操作的语言 或者它是否具有对操作
  • 在 Java Jersey 2 JAX-RS 中初始化单例

    我是泽西岛 2 22 2 的新手 请耐心等待 我正在创建一个与 LDAP 服务器交互的 REST 服务 用于存储 删除和检索用户数据 该服务通过执行加密 解密充当安全中介 在使用 REST 服务之前必须进行相当多的初始化 并且我只想执行此初
  • LinkedBlockingQueue 抛出 InterruptedException

    我有这段代码 ALinkedBlockingQueue应该只抛出一个Exception如果在等待添加到队列时被中断 但这个队列是无限的 所以它应该尽快添加 为什么我的关闭方法会抛出一个InterruptedException private
  • 使用 JPA 和 Hibernate 时 DISTINCT 如何工作

    DISTINCT 在 JPA 中使用什么列 是否可以更改它 以下是使用 DISTINCT 的 JPA 查询示例 select DISTINCT c from Customer c 这没有多大意义 不同的列是基于哪一列 它是否在实体上指定为注

随机推荐

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

    一个成功的软件产品通常需要包含以下几个方面 可靠性 软件产品需要稳定可靠 能够正确地运行 并且在用户使用中没有频繁崩溃或者其他问题 安全性 软件产品在使用过程中需要保证数据的安全性 包括用户的个人和商业隐私等方面 易用性 软件产品需要具有高
  • 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 计数器 限流 消息队列 购物车