面试题:如何保证缓存与数据库双写时的数据一致性?

在处理缓存与数据库双写时,为保证数据一致性,文章探讨了四个方案:先更新数据库后更新缓存(有并发风险)、先更新缓存后更新数据库(可能导致数据不一致)、先删除缓存后更新数据库(可能引入脏数据)以及先更新数据库后删除缓存(可能存在删除失败的风险)。解决方案包括延时双删策略、更新与读取操作异步串行化和利用消息队列补偿删除操作。文章还提到了在主从数据库架构下如何处理数据同步延迟问题。
摘要由CSDN通过智能技术生成

背景:使用到缓存,无论是本地内存做缓存还是使用 Redis 做缓存,那么就会存在数据同步的问题,因为配置信息缓存在内存中,而内存时无法感知到数据在数据库的修改。这样就会造成数据库中的数据与缓存中数据不一致的问题。

共有四种方案:

  1. 先更新数据库,后更新缓存
  2. 先更新缓存,后更新数据库
  3. 先删除缓存,后更新数据库
  4. 先更新数据库,后删除缓存

第一种和第二种方案,没有人使用的,因为第一种方案存在问题是:并发更新数据库场景下,会将脏数据刷到缓存。
第二种方案存在的问题是:如果先更新缓存成功,但是数据库更新失败,则肯定会造成数据不一致。
目前主要用第三和第四种方案。

  1. 先删除缓存,后更新数据库
    该方案也会出问题,此时来了两个请求,请求 A(更新操作) 和请求 B(查询操作)
    1.请求A进行写操作,删除缓存
    2.请求B查询发现缓存不存在
    3.请求B去数据库查询得到旧值
    4.请求B将旧值写入缓存
    5.请求A将新值写入数据库
    上述情况就会导致不一致的情形出现。而且,如果不采用给缓存设置过期时间策略,该数据永远都是脏
    数据。
    答案一:延时双删
    最简单的解决办法延时双删
    使用伪代码如下:
    在这里插入图片描述
    转化为中文描述就是
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值