缓存更新策略

缓存更新是Redis为了节约内存而设计出来的一个东西,主要是因为内存数据宝贵,当我们向redis插入太多数据,此时就可能会导致缓存中的数据过多,所以redis会对部分数据进行更新,或者淘汰。

1.缓存更新策略

1.1.内存淘汰

redis自动进行,当redis内存达到咱们设定的max-memery的时候,会自动触发淘汰机制,淘汰掉一些不重要的数据(可以自己设置策略方式)

1.2超时剔除

当我们给redis设置了过期时间TTL之后,redis会将超时的数据进行删除,方便咱们继续使用缓存

1.3.主动更新

我们可以手动调用方法把缓存删掉,通常用于解决缓存和数据库不一致问题

2.三种策略的区别

|------|-------------------------------------------------|-----------------------------------|------------------------|
| | 内存淘汰 | 超时剔除 | 主动更新 |
| 特点 | 不用自己维护,利用Redis的内存淘汰机制,当内存不足时自动淘汰部分数据。下次查询时更新缓存。 | 给缓存数据添加TTL时间,到期后自动删除缓存。下次查询时更新缓存。 | 编写业务逻辑,在修改数据库的同时,更新缓存。 |
| 一致性 | 差 | 差 | 好 |
| 维护成本 | 无 | 低 | 高 |

2.1使用场景

**低一致性需求:**使用内存淘汰机制。例如店铺类型的查询缓存

**高一致性需求:**主动更新,并以超时剔除作为兜底方案。例如店铺详情查询的缓存

相关推荐
独断万古他化11 小时前
【抽奖系统开发实战】Spring Boot 抽奖系统全链路总结:从架构到落地的实践复盘
java·spring boot·后端·架构·系列总结
编程之升级打怪11 小时前
简单的测试搜索词的分割算法思路
java·算法
码界奇点11 小时前
基于Spring MVC和MyBatis的妖气山视频管理系统设计与实现
java·spring·毕业设计·mvc·mybatis·源代码管理
东离与糖宝11 小时前
小米MiMo-V2-Pro开放调用,Java后端快速接入全流程实战
java·人工智能
王ASC11 小时前
Java不重启加载新的class文件
java·开发语言
靠沿11 小时前
【优选算法】专题十七——多源BFS(最短路径问题)
java·算法·宽度优先
小江的记录本11 小时前
【HashMap】HashMap 系统性知识体系全解(附《HashMap 面试八股文精简版》)
java·前端·后端·容器·面试·hash·哈希
yuuki23323311 小时前
【Linux】Linux基本指令 & 权限全解析
java·linux·服务器
⑩-11 小时前
Kafka 架构和工作原理?Kafka 如何保证高可用?
java·分布式·架构·kafka
indexsunny11 小时前
互联网大厂Java面试实战:从Spring Boot到微服务与Kafka的深度探讨
java·spring boot·junit·kafka·mybatis·hibernate·microservices