阿里云代理商-阿里云服务器-阿里云数据库-重庆典名科技

缓存与数据库双写一致

发布时间: 2020-08-06 10:09:45文章作者: 网站编辑阅读量: 358
  缓存与数据库双写一致
  
  如果仅仅是读数据,没有此类问题
  
  如果是新增数据,也没有此类问题
  
  当数据需要更新时,如何保证缓存与数据库的双写一致性?
  
  三种更新策略:
  
  先更新数据库,再更新缓存 ->
  
  先删除缓存,再更新数据库
  
  先更新数据库,再删除缓存
  
  方案一:并发的时候,执行顺序无法保证,可能A先更新数据库,但B后更新数据库但先更新缓存
  
  ? 加锁的话,确实可以避免,但这样吞吐量会下降,可以根据业务场景考虑
  
  方案二:该方案会导致不一致的原因是。同时有一个请求A进行更新操作,另一个请求B进行查询操作。那么会出现如下情形:
  
  (1)请求A进行写操作,删除缓存
  
  (2)请求B查询发现缓存不存在
  
  (3)请求B去数据库查询得到旧值
  
  (4)请求B将旧值写入缓存
  
  (5)请求A将新值写入数据库
  
  因此采用:采用延时双删策略 即进入逻辑就删除Key,执行完操作,延时再删除key
  
  方案三:更新数据库 - 删除缓存 可能出现问题的场景:
  
  (1)缓存刚好失效
  
  (2)请求A查询数据库,得一个旧值
  
  (3)请求B将新值写入数据库
  
  (4)请求B删除缓存
  
  (5)请求A将查到的旧值写入缓存
  
  先天条件要求:请求第二步的读取操作耗时要大于更新操作,条件较为苛刻
  
  但如果真的发生怎么处理?
  
  A. 给键设置合理的过期时间
  
  B. 异步延时删除key
联系客服免费领取更多阿里云产品新购、续费升级折扣,叠加官网活动折上折更优惠