缓存层与数据库层数据同步

技术缓存层与数据库层数据同步 缓存层与数据库层数据同步缓存层与数据库层数据同步问题
在实际的业务开发中,为了避免大量请求直接操作数据库,我们会用redis做一个缓存层,用户的数据库请求先在redis中查

缓存层和数据库层之间的数据同步。

缓存层与数据库层数据同步问题

在实际的业务开发中,为了避免大量的请求直接操作数据库,我们将使用redis作为缓存层。用户的数据库请求将首先在redis中查询,一旦找到就会返回。如果找不到它们,它们将从数据库中获取数据来更新缓存,然后返回。

这涉及到如何保持缓存层和数据库层之间的数据一致。

一、旁路缓存方案

写入时,先修改数据库,然后删除相关缓存。

删除缓存而不更新的原因主要基于:

一些缓存更新涉及多个表之间的复杂操作,频繁更新会消耗性能。如果未删除缓存,则每次更新数据库时都会计算缓存,但删除缓存后,只有在下一个请求到来时才会计算缓存。

这种方案的缺点是,当删除缓存失败时,客户将读取旧数据,直到下一次数据更新。

二、双写一致方案

在更新数据库之前删除缓存。

通过首先删除缓存,防止用户读取旧数据。

这种方案的缺点是:如果数据库更新失败,用户仍然会读取旧数据,但不会出现不一致;如果请求是在数据库更新完成之前发出的,缓存仍然会加载到旧数据中,从而导致不一致。

三、延时双删方案

首先删除缓存,然后更新数据库。更新成功后,再次异步删除缓存。

这确保了在数据库成功更新后,缓存中的数据在一定时间后必须是更新的数据。

缺点:从成功的数据更新到成功的第二次缓存删除,用户可能会在短时间内读取旧数据。

总结

三种方案都不能称之为完美,使用时要根据需要选择。如果对数据一致性要求比较高,应该选择延迟和双重删除。如果不要求数据一致性且并发性不高,则选择双写一致性或绕过缓存。

当然,如果我们想要追求完美的数据一致性,就必须使用串行请求,但这将大大降低网络吞吐量。

内容来源网络,如有侵权,联系删除,本文地址:https://www.230890.com/zhan/61500.html

(0)

相关推荐

  • 如何利用C++ OpenCV 实现从投影图像恢复仿射特性

    技术如何利用C++ OpenCV 实现从投影图像恢复仿射特性如何利用C++ OpenCV 实现从投影图像恢复仿射特性,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易

    攻略 2021年11月29日
  • c1驾照几年审一次,驾照c本,多久年检一次啊

    技术c1驾照几年审一次,驾照c本,多久年检一次啊驾照c本在换证时才需要年检c1驾照几年审一次。 根据《机动车驾驶证申领和使用规定》:
    第七十条 机动车驾驶人应当按照法律、行政法规的规定,定期到公安机关交通管理部门接受审

    生活 2021年10月28日
  • pagerank算法原理举例子(pagerank算法详解)

    技术PageRank算法如何给网页排名PageRank算法如何给网页排名,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。1,PageRank 算法原理Page

    攻略 2021年12月23日
  • 最早的汽车,世界上成立最早的汽车品牌是

    技术最早的汽车,世界上成立最早的汽车品牌是世界上最早的汽车应该是奔驰l770年法国人尼古拉斯古诺汽车诞生之前马车就是人类最好的陆上交通工具。l770年法国人尼古拉斯古诺(1725一1804)将蒸汽机装在板车上最早的汽车,

    生活 2021年10月21日
  • 青年的年龄,青年人一般指的是几岁到几岁

    技术青年的年龄,青年人一般指的是几岁到几岁青年人一般是20-44周岁青年的年龄。 【年龄段划分】
    中国的年龄分段:   
    1、童年。   
    0岁—6岁(周岁,下同) 
    (1)婴儿期0-3周月;
    (2)小儿期4周

    生活 2021年10月22日
  • 怎么使用css伪元素before和after

    技术怎么使用css伪元素before和after这篇文章主要讲解了“怎么使用css伪元素before和after”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么使用cs

    攻略 2021年11月15日