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

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

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

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

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

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

一、旁路缓存方案

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

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

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

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

二、双写一致方案

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

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

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

三、延时双删方案

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

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

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

总结

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

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

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

(0)

相关推荐

  • 抖音刷赞网站,抖音加粉刷赞平台自助?

    技术抖音刷赞网站,抖音加粉刷赞平台自助?相信大家都喜欢刷抖音、看抖音的习惯,仿佛都中了抖音的毒,戒也戒不掉,一天不看抖音总觉得少了什么,可是大家又知不知道,看抖音到底有哪些危害呢?今天小编就来给大家讲一讲,希望能给大家提

    测评 2021年11月9日
  • 双指针

    技术双指针 双指针双指针799. 最长连续不重复子序列
    给定一个长度为 \(n\) 的整数序列,请找出最长的不包含重复的数的连续区间,输出它的长度。
    输入格式
    第一行包含整数 \(n\)。
    第二行包含

    礼包 2021年11月15日
  • 如何使用基于scriptsetup语法的vue3

    技术如何进行vue3基于script setup语法$refs的使用如何进行vue3基于script setup语法$refs的使用,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小

    攻略 2021年12月18日
  • MySQL面试题有哪些

    技术MySQL面试题有哪些本篇内容介绍了“MySQL面试题有哪些”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!非关系型数

    攻略 2021年12月3日
  • js 定时器的用法和清除

    技术js 定时器的用法和清除 js 定时器的用法和清除一、设置定时器window对象提供了两个方法来实现定时器的效果,分别是window.setTimeout()和window.setInterval。

    礼包 2021年11月14日
  • 技盖至此乎,成语游刃有出自寓言故事,)

    技术技盖至此乎,成语游刃有出自寓言故事,)成语游刃有出自寓言故事(庖丁解牛技盖至此乎,游刃有余)庖丁解牛 ( páo dīng jiě niú ) 庖丁:名叫丁的厨师;解:肢解分割。比喻经过反复实践,掌握了事物的客观规律

    生活 2021年10月20日