缓存更新策略


最常用、应用最广泛的是第一个:Cache Aside Pattern(旁路缓存模式)。

为了帮你更好地理解,我们可以从场景选择和优缺点来剖析一下:

  1. Cache Aside Pattern (旁路缓存) ------ 工业界的首选
    这是目前绝大多数互联网应用最通用的做法。

适用场景:读多写少的场景(绝大多数 Web 应用)。

逻辑:应用代码直接与数据库和缓存交互。

读数据:先读缓存,没命中再读数据库,并将数据写入缓存。

写数据:先更新数据库,然后直接删除缓存(注意:是删除而不是更新)。

为什么用它:

灵活性:你可以完全控制缓存的失效逻辑。

容错性:如果缓存服务宕机,程序依然可以从数据库读取,系统不会瘫痪(数据库压力虽会瞬间增大,但系统可用)。

一致性:采用"先删缓存,后更新数据库"或者"先更新数据库,再删缓存"的组合策略,可以很好地权衡性能与数据一致性。

  1. Read/Write Through Pattern
    适用场景:对数据一致性要求极高,且希望缓存层对上层应用透明的场景。

特点:应用只负责和缓存交互,缓存层会自动去和数据库同步。

缺点:在 Java 后端开发(如使用 Redis + MySQL)中,这种模式实现起来较复杂,通常需要引入额外的中间件或框架来代理这一层逻辑,且缓存层如果出现故障,整个系统会直接受到影响。

  1. Write Behind Caching Pattern (又称 Write Back)
    适用场景:极致的写入性能要求,如高频计数器、实时排行、日志分析等。

特点:应用只管更新缓存,缓存通过异步队列慢慢同步到数据库。

风险:如果缓存服务在同步给数据库之前宕机,会导致数据丢失。它保证的是最终一致性,不保证强一致性。因此,除非对实时性要求极高且能容忍少量数据丢失,否则一般不用于关键的业务数据。


相关推荐
IAUTOMOBILE6 分钟前
Python 流程控制与函数定义:从调试现场到工程实践
java·前端·python
hutengyi6 分钟前
PostgreSQL版本选择
java
皮皮林55112 分钟前
重磅!JetBrains 正式发布全新的 AI 开发工具,定名 AI IDE AIR
java·intellij idea
MX_935925 分钟前
SpringMVC请求参数
java·后端·spring·servlet·apache
ID_1800790547331 分钟前
小红书笔记评论 API,Python 调用示例与完整 JSON 返回参考
java·开发语言
lifewange35 分钟前
java连接Mysql数据库
java·数据库·mysql
云原生指北1 小时前
命令行四件套:fd-rg-fzf-bat
java·大数据·elasticsearch
人间打气筒(Ada)2 小时前
go实战案例:如何通过 Service Meh 实现熔断和限流
java·开发语言·golang·web·istio·service mesh·熔断限流
主宰者3 小时前
C# CommunityToolkit.Mvvm全局事件
java·前端·c#
计算机学姐3 小时前
基于SpringBoot的咖啡店管理系统【个性化推荐+数据可视化统计+配送信息】
java·vue.js·spring boot·后端·mysql·信息可视化·tomcat