【无标题】

旁路缓存笔记

参考了小林coding和java全栈知识体系的文章

逻辑:

读:先读缓存,如果缓存中不存在就读数据库,然后更新缓存

写:先更新数据库,再删除缓存

具体逻辑:

失效:应用程序先从cache获取数据,如果没有得到,则从数据库中取数据数据,成功后放入缓存中

命中:命中后直接缓存

更新:先把数据库中的数据更新,然后删除缓存

先读后写问题

先读取cache发现为空,然后去db写入,随后一个写入请求写入db并删除cache,然后写操作再去cache写入。

这种情况会导致cache中存储的仍然是旧的数据。所以我们需要给缓存设置过期时间。

上面这个问题的发生的可能性不高,因为缓存写入的速度一般远远快于数据库更新+删除的速度。而且还有本身缓存过期时间的兜底,即使发生了先读后写导致的bug,也只是之前的数据没更新,等缓存的时间一过就可以访问了。

回写缓存失败问题

接下来还有问题:如果更新数据库+删除缓存这一套流程中,第二步删除缓存失败这个操作丢失怎么办?

通常来讲有两个解决方案:

1.消息队列重试机制 2. 订阅MySQL binlog,再操作缓存

消息队列重试机制

引入消息队列,将第二个操作要操作的数据加入到消息队列,让消费者来进行以下操作:

1.如果删除缓存失败,则进行重试,如果重试次数超过阈值,就返回给业务层报错

2.如果删除缓存成功,就要把数据从消息队列中移除。

这个方法有个问题就是对业务线有大的侵入。

异步更新缓存(基于订阅binlog的同步机制)

这个方案与消息队列的不同之处在于使用了数据库的binlog日志 ,然后订阅binlog来监控操作,一旦发现binlog中有更新的指令,就推送到非业务代码中执行前面的消息队列重试机制,好处就是因为监听的是数据库,所以对业务代码基本没有影响。

业界一般都是用的是binlog的异步更新缓存策略,可以使用阿里的中间件Canal来做binlog异步同步。

相关推荐
似水明俊德8 小时前
04-C#.Net-委托和事件-面试题
java·开发语言·面试·c#·.net
深蓝电商API8 小时前
缓存策略在海淘代购系统中的应用
缓存·系统架构·跨境电商·代购系统·反向海淘·代购平台
海南java第二人8 小时前
Cursor 高级实战:从 Spring Boot 到微服务,AI 驱动的全流程开发指南
人工智能·spring boot·微服务
好家伙VCC8 小时前
# 发散创新:用 Rust构建高性能游戏日系统,从零实现事件驱动架构 在现代游戏开发中,**性能与可扩展性**是核心命题。传统基于
java·python·游戏·架构·rust
爱笑的源码基地8 小时前
门诊his系统源码,中西医结合的数字化门诊解决方案
java·spring boot·源码·二次开发·门诊系统·云诊所系统·诊所软件源码
庞轩px8 小时前
缓存Key设计的“七要七不要”
java·jvm·redis·缓存
小璐资源网8 小时前
Java 21 新特性实战:虚拟线程详解
java·开发语言·python
SimonKing8 小时前
全网爆火的OpenClaw保姆级教程Linux版,它来了。
java·后端·程序员
于慨9 小时前
tauri
java·服务器·前端
WZTTMoon9 小时前
从互斥锁到无锁,Java 20年并发安全进化史
java·python·安全