您的位置:首页 > 汽车 > 时评 > 如何保证Redis与数据库的数据一致性

如何保证Redis与数据库的数据一致性

2024/7/2 4:22:51 来源:https://blog.csdn.net/weixin_38316697/article/details/139596839  浏览:    关键词:如何保证Redis与数据库的数据一致性

文章目录

  • 前言
    • 如何保证Redis与数据库的数据一致性
      • 1. 先删除缓存,在写数据库怎么保证
      • 2. 先写数据库,在删缓存怎么保证

前言

  如果您觉得有用的话,记得给博主点个赞,评论,收藏一键三连啊,写作不易啊^ _ ^。
  而且听说点赞的人每天的运气都不会太差,实在白嫖的话,那欢迎常来啊!!!


如何保证Redis与数据库的数据一致性

1. 先删除缓存,在写数据库怎么保证

如果先删除缓存,在写数据库,当第一个线程删除了缓存,还没有来得及写数据库,第二个线程来读取数据,就会发现缓存中的数据为空,那就会读取数据库中的旧值,读取完之后,把读取的旧值存入缓存中(此时第一个线程已经将新值存入缓存中),这样缓存中的值就会被覆盖为修改前的脏数据。

解决方案:
(1)先操作缓存,但是不删除缓存,将缓存修改为一个默认值(-+++999999),当客户端请求被缓存拦截时发现是这个默认值,就休眠一小会再去查一次redis。
问题:这个特殊值是对业务有侵入,休眠时间内,可能多次访问,对性能有影响。

(2)延时双删:先删除缓存,然后写入数据库,休眠一小会,再次删除缓存。
问题:如果数据写作操作很频繁,同样还是会有脏数据产生。

总觉:在这种方式下,通常要求写操作不频繁。

2. 先写数据库,在删缓存怎么保证

先写数据库,在删缓存,如果数据写完之后,删除缓存失败,就会导致数据不一致。

解决方案:
(1)给缓存设置一个过期时间。
问题:过期时间内,缓存数据不会更新。
(2)引入MQ,保证原子操作。

总结:始终只能保证一段时间内的最终一致性。

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com