首页
学习
活动
专区
圈层
工具
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

谈谈缓存更新

看到好些人在写更新缓存数据代码时,先删除缓存,然后再更新数据库,而后续的操作会把数据再装载的缓存中。然而,这个是逻辑是错误的。...试想,两个并发操作,一个是更新操作,另一个是查询操作,更新操作删除缓存后,查询操作没有命中缓存,先把老数据读出来后放到缓存中,然后更新操作更新了数据库。...这里,我们先不讨论更新缓存和更新数据这两个事是一个事务的事,或是会有失败的可能,我们先假设更新数据库和更新缓存都可以成功的情况(我们先把成功的代码逻辑先写对)。...Write Back套路,一句说就是,在更新数据的时候,只更新缓存,不更新数据库,而我们的缓存会异步地批量更新数据库。...4、上面,我们没有考虑缓存(Cache)和持久层(Repository)的整体事务的问题。比如,更新Cache成功,更新数据库失败了怎么吗?或是反过来。

1.1K20

缓存雪崩、缓存穿透、缓存预热、缓存更新、缓存降级等问题!

,今天给大家整理一篇关于Redis经常被问到的问题:缓存雪崩、缓存穿透、缓存预热、缓存更新、缓存降级等概念的入门及简单解决方案。...(2)还有一个解决办法解决方案是:给每一个缓存数据增加相应的缓存标记,记录缓存的是否失效,如果缓存标记失效,则更新数据缓存,实例伪代码如下: ?...解释说明: 1、缓存标记:记录缓存数据是否过期,如果过期会触发通知另外的线程在后台去更新实际key的缓存; 2、缓存数据:它的过期时间比缓存标记的时间延长1倍,例:标记缓存时间30分钟,数据缓存设置为60...这样,当缓存标记key过期后,实际缓存还能把旧数据返回给调用端,直到另外的线程在后台更新完成后,才会返回新缓存。...关于缓存崩溃的解决方法,这里提出了三种方案:使用锁或队列、设置过期标志更新缓存、为key设置不同的缓存失效时间,还有一各被称为“二级缓存”的解决方法,有兴趣的读者可以自行研究。

3.8K10
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    漫谈缓存更新之道

    许多人在更新缓存时,先删除缓存,然后再更新数据库,而后续的操作会把数据再装载入缓存中。 然而,这个逻辑是错误的!!!...试想,两个并发操作,一个更新,一个查询,更新删除缓存后,查询没有命中缓存,先把旧数据读出来后放到缓存中,然后更新操作更新了数据库。于是,在缓存中的数据还是旧数据,导致缓存中持续地产生脏数据....这里,我们先不讨论更新缓存和更新数据这两个事是一个事务的事,或是会有失败的可能,我们先假设更新数据库和更新缓存都可以成功的情况 更新缓存的的Design Pattern有四种 1 Cache Aside...,成功后,让缓存失效 一个查询操作,一个更新操作的并发 首先,没有了删除cache数据的操作,而是先更新数据库中的数据,此时,缓存依然有效,所以,并发的查询操作拿的是没有更新的数据,但是,更新操作马上让缓存的失效了...则用缓存服务自己来加载,从而对应用方是透明的 2.2 Write Through 和Read Through相仿,不过是在更新数据时发生 当有数据更新时 如果没有命中缓存,直接更新数据库,然后返回

    3.2K31

    缓存更新的套路

    看到好些人在写更新缓存数据代码时,先删除缓存,然后再更新数据库,而后续的操作会把数据再装载的缓存中。然而,这个是逻辑是错误的。...试想,两个并发操作,一个是更新操作,另一个是查询操作,更新操作删除缓存后,查询操作没有命中缓存,先把老数据读出来后放到缓存中,然后更新操作更新了数据库。...Write Back套路,一句说就是,在更新数据的时候,只更新缓存,不更新数据库,而我们的缓存会异步地批量更新数据库。...4)上面,我们没有考虑缓存(Cache)和持久层(Repository)的整体事务的问题。比如,更新Cache成功,更新数据库失败了怎么吗?或是反过来。...(完) 转自陈皓, 出处:http://coolshell.cn/articles/17416.html 版权申明:内容来源网络,版权归原创者所有。

    2.2K70

    使用ZBlog搭建网站 怎么选择HTML静态缓存插件

    纯静态插件和静态缓存插件的区别 纯静态插件   网页通过链接在网站的对应目录生成HTML静态文件。   ...静态缓存插件   所有网页都在指定目录(例如插件的所在目录)生成HTML静态文件,而不会像纯静态插件在网站主目录生成HTML静态网页文件和创建不同的子目录。 什么网站可以使用静态插件?...如果网站首页也需要静态,网站的默认文件优先级,html放在第一个。 这个价位的纯静态插件只有这一款,暂时就推荐这一款,价格超过65元建议选择静态缓存插件,功能更多。...,例如分类页、标签页、作者页和日期页),发表/更新文章、评论、标签、日期等自动刷新该网页的静态缓存,一键刷新全站缓存,价格127元 2、静态缓存页面生成:https://app.zblogcn.com...id=2311   目前ZBlog最便宜的静态缓存插件,从该插件的更新内容来看,支持登录用户访问动态网页,自动删除静态缓存文件(某网页长时间没人访问,自动删除该缓存文件,减少存储空间占用),发表文章、评论删除缓存文件

    1.7K20

    缓存更新的套路

    试想,两个并发操作,一个是更新操作,另一个是查询操作,更新操作删除缓存后,查询操作没有命中缓存,先把老数据读出来后放到缓存中,然后更新操作更新了数据库。...这里,我们先不讨论更新缓存和更新数据这两个事是不是一个事务的事,或是会有失败的可能,我们先假设更新数据库和更新缓存都可以成功的情况(我们先把成功的代码逻辑先写对)。...Write Back 套路,一句说就是,在更新数据的时候,只更新缓存,不更新数据库,而我们的缓存会异步地批量更新数据库。...4)上面,我们没有考虑缓存(Cache)和持久层(Repository)的整体事务的问题。比如,更新 Cache 成功,更新数据库失败了怎么吗?或是反过来。.../documentation/3.0/xa.html [6] 分布式系统的事务处理: https://coolshell.cn/articles/10910.html

    1.3K20

    缓存更新的套路

    看到好些人在写更新缓存数据代码时,先删除缓存,然后再更新数据库,而后续的操作会把数据再装载的缓存中。然而,这个是逻辑是错误的。...试想,两个并发操作,一个是更新操作,另一个是查询操作,更新操作删除缓存后,查询操作没有命中缓存,先把老数据读出来后放到缓存中,然后更新操作更新了数据库。...这里,我们先不讨论更新缓存和更新数据这两个事是一个事务的事,或是会有失败的可能,我们先假设更新数据库和更新缓存都可以成功的情况(我们先把成功的代码逻辑先写对)。...Write Back套路,一句说就是,在更新数据的时候,只更新缓存,不更新数据库,而我们的缓存会异步地批量更新数据库。...4)上面,我们没有考虑缓存(Cache)和持久层(Repository)的整体事务的问题。比如,更新Cache成功,更新数据库失败了怎么吗?或是反过来。

    1.3K130

    缓存更新策略

    问题:项目中,Redis用了缓存热点数据,持久化数据在MySQL DB中;那么Redis缓存数据什么时候更新呢? 方法A: 步骤:1....删除缓存,2.更新DB , 3.下一次读操作没有命中缓存时,更新缓存; 存在的问题:如果另外一个读任务发生在"更新DB"之前,那么缓存就"更新DB"之前的“脏数据”; 方法B:...步骤:1.更新DB,2.更新缓存; 存在的问题:如果发生并发“更新数据”,程序不能保证“更新缓存”的先后顺序,存在“脏数据”的可能性; 方法C:...下一次读操作没有命中缓存时,更新缓存; 存在的问题:如果在步骤1“更新DB”之前,有一个并发读任务没有命中缓存,从DB读取到“老数据”,在步骤2之后才把“老数据”更新到缓存,那么缓存中就是...“脏数据”; 思考:方法C采取的策略,在实际场景中发送的概率比前两种方法小很多;但是怎么完全杜绝这种问题呢?

    1.5K00

    Redis缓存雪崩、缓存穿透、缓存预热、缓存更新、缓存降级等问题

    一、缓存雪崩 由于原有缓存失效,新缓存未到期间,比如我们设置缓存时采用了相同的过期时间,在同一时刻出现大面积的缓存过期,所有原本应该访 问缓存的请求都去查询数据库了,而对数据库CPU和内存造成巨大压力,...(2)还有一个简单方案就时将缓存失效时间分散开。 二、缓存穿透 缓存穿透是指用户查询数据,在数据库没有,自然在缓存中也不会有。...三、缓存预热 缓存预热这个应该是一个比较常见的概念,相信很多人都应该可以很容易的理解,缓存预热就是系统上线后,将相关的缓存数据直接加载到缓存系统。...用户直接查询事先被预热的缓存数据 解决办法 (1)直接写个缓存刷新页面,上线时手工操作下; (2)数据量不大,可以在项目启动的时候自动进行加载; (3)定时刷新缓存; 四、缓存更新 除了缓存服务器自带的缓存失效策略之外...,过期的话就去底层系统得到新数 据并更新缓存。

    2.2K20

    怎么缓存当前的组件?缓存后怎么更新?

    只有名称匹配的组件会被缓存 exclude - 字符串或正则表达式。任何名称匹配的组件都不会被缓存 max - 数字。...)–>返回到首页(需要缓存)–>再次进入列表页(不需要缓存),这时候可以按需来控制页面的keep-alive 在路由中设置keepAlive属性判断是否需要缓存 { path: 'list',...中缓存组件的数量是否超过了设置的最大缓存数量值this.max,如果超过了,则把第一个缓存组件删掉 四、思考题:缓存后如何获取数据 解决方案可以有以下两种: beforeRouteEnter actived...{ this.getData() // 获取数据 }, 注意:服务器端渲染期间avtived不被调用 参考文献 https://www.cnblogs.com/dhui/p/13589401.html...https://www.cnblogs.com/wangjiachen666/p/11497200.html https://vue3js.cn/docs/zh

    2.7K21

    【缓存】HTML5缓存的那些事

    ,然后把这些缓存在浏览器中,并更新相应的app cache文件;如果manifest这个文件没有更新,那么就啥也不做。...从上图,我们总结2点: 缓存机制的改变,会更新app cache.但是,用户访问,会返回上一次的结果。这样一来,会有一个麻烦,即如果你的业务发生更改,你就需要去更新一次manifest。...app cache缺陷: 含有manifest属性的当前请求页无论如何都会被缓存; 更新需要建立在manifest文件的更新,文件更新后是需要页面再次刷新的,并且在第2次刷新才能获取新资源; 更新是全局性的...,无法单独更新某个文件; 对于链接的参数变化的敏感的,任何一个参数的修改都会被重新缓存,例如:index.html和index.html?...关于HTML5缓存我们就介绍到这里。 参考 HTML5之IndexedDB使用详解

    41550

    为什么是删除缓存,而不是更新缓存?

    原因很简单,很多时候,在复杂点的缓存场景,缓存不单单是数据库中直接取出来的值。 比如可能更新了某个表的一个字段,然后其对应的缓存,是需要查询另外两个表的数据并进行运算,才能计算出缓存最新的值的。...另外更新缓存的代价有时候是很高的。是不是说,每次修改数据库的时候,都一定要将其对应的缓存更新一份?也许有的场景是这样,但是对于比较复杂的缓存数据计算的场景,就不是这样了。...如果你频繁修改一个缓存涉及的多个表,缓存也频繁更新。但是问题在于,这个缓存到底会不会被频繁访问到?...2)最初级的缓存不一致问题及解决方案 问题:先更新数据库,再删除缓存。如果删除缓存失败了,那么会导致数据库中是新数据,缓存中是旧数据,数据就出现了不一致。 解决思路:先删除缓存,再更新数据库。...如果数据库更新失败了,那么数据库中是旧数据,缓存中是空的,那么数据不会不一致。因为读的时候缓存没有,所以去读了数据库中的旧数据,然后更新到缓存中。

    18010

    Redis 缓存击穿(失效)、缓存穿透、缓存雪崩怎么解决?

    当请求进来的时候,先从缓存中取数据,如果有则直接返回缓存中的数据。 如果缓存中没数据,就去数据库中读取数据并写到缓存中,再返回结果。 这样就天衣无缝了么?...缓存的设计不当,将会导致严重后果,本文将介绍缓存使用中常见的三个问题和解决方案: 缓存击穿(失效); 缓存穿透; 缓存雪崩。...缓存雪崩 缓存雪崩指的是大量的请求无法在 Redis 缓存系统中处理,请求全部打到数据库,导致数据库压力激增,甚至宕机。...一旦 Redis 宕机,会导致大量请求打到数据库,从而发生缓存雪崩。 解决方案 对于缓存系统故障导致的缓存雪崩的解决方案有两种: 服务熔断和接口限流; 构建高可用缓存集群系统。...,继续提供缓存服务,避免了由于缓存实例宕机而导致的缓存雪崩问题。

    1.5K10

    html5空格代码怎么写_html怎么添加空格

    本篇文章为大家介绍的是HTML的空格代码的写法,“ ;”代码的用法,还有几种空格方式的解释,都在文章中,现在开始往下看吧。 首先,我们知道这HTML网页中插入多个空格间隔是需要特殊字符编码的。...接下来教大家如果输入html空格字符的话,多个空格字符是如何输入的?我们采用直接复制空格字符与DW软件输入空格字符的两种方法介绍: 第一种叫Html空格字符语法代码: 就是这个代码“ ”。...” 然后在“HTML”弹出选项中选择“特殊字符”最后再选择点击“不换行空格”,这样输入“ ”空格的字符代码,如果输入多个空格字符按照以上操作即可输入多个html空格字符。...你可以记住html空格字符拼写字母与字符,也都很简单。...这个方法只适用于HTML,如果你使用CSS的话,不推荐这一方法 在HTML文档的部分,插入以下命令: p.indent{ padding-left: 1.8em

    9.2K20

    缓存层场景实战读缓存,如何更新缓存+缓存的高可用设计+监控

    2)假设第一步成功了,第二步失败了怎么办? 3)假设两个线程同时更新同一个数据,A线程先完成第一步,B线程先完成第二步怎么办?...◆ 组合1:先更新缓存,再更新数据库 对于这个组合,会遇到这种情况:假设第二步更新数据库失败了,要求回滚缓存的更新,这时该怎么办呢?...◆ 组合3:先更新数据库,再更新缓存 对于组合3,同样需要考虑两个问题。 1)假设第一步(更新数据库)成功,第二步(更新缓存)失败了怎么办?...2)假设两个线程同时更新同一个数据,线程A先完成了第一步,线程B先完成了第二步怎么办?...◆ 组合4:先更新数据库,再删除缓存 针对组合4,先看看它能不能解决组合3的第二个问题。 假设两个线程同时更新同一个数据,线程A先完成第一步,线程B先完成第二步怎么办?

    80310
    领券