redis如何实现缓存预热

在业务系统中,我们需要在程序启动的时候加载一些常用的数据到内存数据库中,从而减少业务数据库的压力。这就是我们常提到的缓存预热。官方一点的解释是这样的:

缓存预热是一种在程序启动或缓存失效之后,主动将热点数据加载到缓存中的策略。这样,在实际请求到达程序时,热点数据已经存在于缓存中,从而减少了缓存穿透和缓存击穿的情况,也缓解了SQL服务器的压力。

shigen结合业务系统,加上自己的设计,写出了这样的设计代码。

  • 定义缓存操作的抽象类

主要是初始化缓存、从缓存中获得数据、清理缓存和刷新缓存的操作。

  • spring boot生命周期的监控

定义在spring boot项目启动之后,立即初始化缓存。在项目结束的时候,立即删除缓存。

  • abstractCache的继承类

这里就是定义的抽象方法的重写,其中:

  1. 初始化: 将全部的热点数据缓存在redis
  2. 查询: key不存在的时候就初始化缓存,否则直接从缓存中获得数据
  3. 删除: 直接删除这个key,用于服务关闭的时候清除缓存

注:

  • 这里的key比较少,采用的是直接删除;但是针对key较多的情况,建议使用游标或者lua脚本删除;
  • 服务关闭的时候清除缓存,这里是为了节约资源🤭🤭
  • 接口类测试

这里就是随便写的一个接口,测试一下是否实现了效果。

好了,以上核心的代码完成了。我们启动服务测试一下效果:

相关的时间段redis的日志是这样的:

在服务启动之后,缓存中就有了数据,接口测试可以直接拿到数据;当服务关闭之后,缓存数据也一并的清空。

好了,以上就是《redis如何实现缓存预热》的全部内容了。需要注意的是:

这种设计方式仅适用于单机模式,对于多实例、分布式服务需要考虑数据的同步问题!

觉得不错的话,记得点赞 关注一下哈,这样就不会错过很多干货了。

shigen一起,每天不一样!

相关推荐
Dragon Wu9 分钟前
SpringCache 缓存使用总结
spring boot·后端·spring·缓存·springcloud
夜瞬27 分钟前
【Flask 框架学习】01:编写第一个 Flask 应用
后端·python·学习·flask
JavaLearnerZGQ27 分钟前
Spring Boot 流式响应接口核心组件解析
java·spring boot·后端
Loo国昌35 分钟前
【AI应用开发实战】07_文档解析路由与质量评估:从传统PDF解析到Docling现代化方案
人工智能·后端·python·自然语言处理·pdf
Pr Young36 分钟前
有限状态机
服务器·后端
凌云拓界38 分钟前
TypeWell全攻略:AI健康教练+实时热力图开发实战 引言
前端·人工智能·后端·python·交互·pyqt·数据可视化
UrbanJazzerati1 小时前
Python Logging库完全指南:从小白到熟练
后端·面试
毕设源码-赖学姐1 小时前
【开题答辩全过程】以 基于SpringBoot Vue的网络课程销售管理系统为例,包含答辩的问题和答案
java·spring boot·后端
Gopher_HBo1 小时前
Go进阶之示例测试原理
后端
钟智强1 小时前
深度剖析CVE-2023-41064与CVE-2023-4863:libwebp堆溢出漏洞的技术解剖与PoC构建实录
前端·后端