redis 双写一致性

本文探讨了Redis缓存更新的三种策略:先更新数据库再更新缓存、先删除缓存再更新数据库、先更新数据库再删除缓存。详细分析了各自的优缺点和可能产生的数据不一致情况,并给出了相应的解决方案,包括延时双删策略和异步删除策略,以及应对删除缓存失败的重试机制。
摘要由CSDN通过智能技术生成

首先,缓存由于其高并发和高性能的特性,已经在项目中被广泛使用。在读取缓存方面,大家没啥疑问,都是按照下图的流程来进行业务操作。



但是在更新缓存方面,对于更新完数据库,是更新缓存呢,还是删除缓存。又或者是先删除缓存,再更新数据库,其实大家存在很大的争议。目前没有一篇全面的博客,对这几种方案进行解析。于是博主战战兢兢,顶着被大家喷的风险,写了这篇文章。

 

文章结构

 

本文由以下三个部分组成


1、讲解缓存更新策略
2、对每种策略进行缺点分析
3、针对缺点给出改进方案

 

正文

 

先做一个说明,从理论上来说,给缓存设置过期时间,是保证最终一致性的解决方案。这种方案下,我们可以对存入缓存的数据设置过期时间,所有的写操作以数据库为准,对缓存操作只是尽最大努力即可。也就是说如果数据库写成功,缓存更新失败,那么只要到达过期时间,则后面的读请求自然会从数据库中读取新值然后回填缓存。因此,接下来讨论的思路不依赖于给缓存设置过期时间这个方案。


在这里,我们讨论三种更新策略:

 

  1. 先更新数据库,再更新缓存

  2. 先删除缓存,再更新数据库

  3. 先更新数据库,再删除缓存

 

应该没人问我,为什么没有先更新缓存,再更新数据库这种策略。

 

(1)先更新数据库,再更新缓存

 

这套方案,大家是普遍反对的。为什么呢?有如下两点原因。


- 原因一(线程安全角度)


同时有请求A和请求B进行更新操作,那么会出现


(1)线程A更新了数据库
(2)线程B更新了数据库
(3)线程B更新了缓存
(4)线程A更新了缓存
 

这就出现请求A更新缓存应该比请求B更新缓存早才对,但是因为网络等原因,B却

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值