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

谈谈缓存更新

看到好些人在写更新缓存数据代码时,先删除缓存,然后再更新数据库,而后续的操作会把数据再装载的缓存中。然而,这个是逻辑是错误的。...试想,两个并发操作,一个是更新操作,另一个是查询操作,更新操作删除缓存后,查询操作没有命中缓存,先把老数据读出来后放到缓存中,然后更新操作更新数据库。...这里,我们先不讨论更新缓存更新数据这两个事是一个事务的事,或是会有失败的可能,我们先假设更新数据库和更新缓存都可以成功的情况(我们先把成功的代码逻辑先写对)。...一个是查询操作,一个是更新操作的并发,首先,没有了删除cache数据的操作了,而是先更新数据库中的数据,此时,缓存依然有效,所以,并发的查询操作拿的是没有更新数据,但是,更新操作马上让缓存的失效了,...Write Back套路,一句说就是,在更新数据的时候,只更新缓存,不更新数据库,而我们的缓存会异步地批量更新数据库。

1.1K20

58一面:Redis数据更新,是先更新数据库还是先更新缓存

每天某个时段的数据流量? 4、如果我在这边频繁刷流量,大约多长时间可以发现异常?? 5、redis作为高速缓存数据库的数据一致性的问题,如果数据更新的话是先更新数据库还是先更新缓存?...---- redis作为高速缓存数据库的数据一致性的问题,如果数据更新的话是先更新数据库还是先更新缓存?...但是在更新缓存方面,对于更新数据库,是更新缓存呢,还是删除缓存。又或者是先删除缓存,再更新数据库,其实大家存在很大的争议。...在这里,我们讨论三种更新策略: 先更新数据库,再更新缓存 先删除缓存,再更新数据库 先更新数据库,再删除缓存 应该没人问我,为什么没有先更新缓存,再更新数据库这种策略。...接下来讨论的就是争议最大的,先删缓存,再更新数据库。还是先更新数据库,再删缓存的问题。 (2)先删缓存,再更新数据库 该方案会导致不一致的原因是。

1.4K40
您找到你想要的搜索结果了吗?
是的
没有找到

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

(2)还有一个解决办法解决方案是:给每一个缓存数据增加相应的缓存标记,记录缓存的是否失效,如果缓存标记失效,则更新数据缓存,实例伪代码如下: ?...解释说明: 1、缓存标记:记录缓存数据是否过期,如果过期会触发通知另外的线程在后台去更新实际key的缓存; 2、缓存数据:它的过期时间比缓存标记的时间延长1倍,例:标记缓存时间30分钟,数据缓存设置为60...这样,当缓存标记key过期后,实际缓存还能把旧数据返回给调用端,直到另外的线程在后台更新完成后,才会返回新缓存。...解决思路: 1、直接写个缓存刷新页面,上线时手工操作下; 2、数据量不大,可以在项目启动的时候自动进行加载; 3、定时刷新缓存; 四、缓存更新 除了缓存服务器自带的缓存失效策略之外(Redis默认的有6...中策略可供选择),我们还可以根据具体的业务需求进行自定义的缓存淘汰,常见的策略有两种: (1)定时去清理过期的缓存; (2)当有用户请求过来时,再判断这个请求所用到的缓存是否过期,过期的话就去底层系统得到新数据更新缓存

3.7K10

​到底是先更新数据库还是先更新缓存

而引入缓存后,我们在向数据库插入数据时,到底是先更新数据库还是先更新缓存呢? 缓存的一般使用 缓存,从本质上讲,是为了更好的协调两个速度差异比较大的组件而引入的一种中间缓存层。...但是在后续更新数据的操作中,是更新数据库,接下来更新缓存还是删除缓存?又或者是先删除缓存,再更新数据库? 缓存更新策略 从理论上来说,给缓存设置过期时间,其实是一中最终一致性的表现。...(1) 线程A更新数据库 (2) 线程B更新数据库 (3) 线程B更新缓存 (4) 线程A更新缓存 此时就会出现数据库中的数据缓存数据不一致的情况,这是因为线程A先更新数据库,可能因为网络等异常情况...,线程B更新数据库进而更新缓存,当线程B更新缓存后,线程A才更新缓存,这就导致了数据数据缓存数据的不一致。...先删除缓存更新数据库 先删除缓存更新数据库的方案也存在着线程安全的问题,例如,线程A更新缓存,同时,线程B读取缓存数据。可能会出现下面的执行顺序。

1.9K20

到底是先更新数据库还是先更新缓存

而引入缓存后,我们在向数据库插入数据时,到底是先更新数据库还是先更新缓存呢? 缓存的一般使用 缓存,从本质上讲,是为了更好的协调两个速度差异比较大的组件而引入的一种中间缓存层。...但是在后续更新数据的操作中,是更新数据库,接下来更新缓存还是删除缓存?又或者是先删除缓存,再更新数据库? 缓存更新策略 从理论上来说,给缓存设置过期时间,其实是一种最终一致性的表现。...(1) 线程A更新数据库 (2) 线程B更新数据库 (3) 线程B更新缓存 (4) 线程A更新缓存 此时就会出现数据库中的数据缓存数据不一致的情况,这是因为线程A先更新数据库,可能因为网络等异常情况...,线程B更新数据库进而更新缓存,当线程B更新缓存后,线程A才更新缓存,这就导致了数据数据缓存数据的不一致。...先删除缓存更新数据库 先删除缓存更新数据库的方案也存在着线程安全的问题,例如,线程A更新缓存,同时,线程B读取缓存数据。可能会出现下面的执行顺序。

1.3K10

漫谈缓存更新之道

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

3.1K31

缓存更新的套路

看到好些人在写更新缓存数据代码时,先删除缓存,然后再更新数据库,而后续的操作会把数据再装载的缓存中。然而,这个是逻辑是错误的。...试想,两个并发操作,一个是更新操作,另一个是查询操作,更新操作删除缓存后,查询操作没有命中缓存,先把老数据读出来后放到缓存中,然后更新操作更新数据库。...这里,我们先不讨论更新缓存更新数据这两个事是一个事务的事,或是会有失败的可能,我们先假设更新数据库和更新缓存都可以成功的情况(我们先把成功的代码逻辑先写对)。...一个是查询操作,一个是更新操作的并发,首先,没有了删除cache数据的操作了,而是先更新数据库中的数据,此时,缓存依然有效,所以,并发的查询操作拿的是没有更新数据,但是,更新操作马上让缓存的失效了,...Write Back套路,一句说就是,在更新数据的时候,只更新缓存,不更新数据库,而我们的缓存会异步地批量更新数据库。

2.1K70

缓存更新的套路

看到好些人在写更新缓存数据代码时,先删除缓存,然后再更新数据库,而后续的操作会把数据再装载的缓存中。然而,这个是逻辑是错误的。...试想,两个并发操作,一个是更新操作,另一个是查询操作,更新操作删除缓存后,查询操作没有命中缓存,先把老数据读出来后放到缓存中,然后更新操作更新数据库。...这里,我们先不讨论更新缓存更新数据这两个事是一个事务的事,或是会有失败的可能,我们先假设更新数据库和更新缓存都可以成功的情况(我们先把成功的代码逻辑先写对)。...一个是查询操作,一个是更新操作的并发,首先,没有了删除cache数据的操作了,而是先更新数据库中的数据,此时,缓存依然有效,所以,并发的查询操作拿的是没有更新数据,但是,更新操作马上让缓存的失效了,...Write Back套路,一句说就是,在更新数据的时候,只更新缓存,不更新数据库,而我们的缓存会异步地批量更新数据库。

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

缓存更新的套路

阅读本文大概需要 10 分钟 原文 | http://sina.lt/gpqN 看到好些人在写更新缓存数据代码时,先删除缓存,然后再更新数据库,而后续的操作会把数据再装载到缓存中。...试想,两个并发操作,一个是更新操作,另一个是查询操作,更新操作删除缓存后,查询操作没有命中缓存,先把老数据读出来后放到缓存中,然后更新操作更新数据库。...这里,我们先不讨论更新缓存更新数据这两个事是不是一个事务的事,或是会有失败的可能,我们先假设更新数据库和更新缓存都可以成功的情况(我们先把成功的代码逻辑先写对)。...命中:应用程序从 cache 中取数据,取到后返回。 更新:先把数据存到数据库中,成功后,再让缓存失效。 ? 注意,我们的更新是先更新数据库,成功后,让缓存失效。...Write Back 套路,一句说就是,在更新数据的时候,只更新缓存,不更新数据库,而我们的缓存会异步地批量更新数据库。

1.3K20

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

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

2.2K20

高并发场景下,到底先更新缓存还是先更新数据库?

踩坑一:先更新数据库,再更新缓存 如果同时有两个写请求需要更新数据,每个写请求都先更新数据库再更新缓存,在并发场景可能会出现数据不一致的情况。 ?...先更新数据库,再更新缓存 如上图的执行过程: (1)写请求1更新数据库,将 age 字段更新为18; (2)写请求2更新数据库,将 age 字段更新为20; (3)写请求2更新缓存缓存 age 设置为...踩坑二:先删缓存,再更新数据库 如果写请求的处理流程是先删缓存更新数据库,在一个读请求和一个写请求并发场景下可能会出现数据不一致情况。 ?...先删缓存,再更新数据库 如上图的执行过程: (1)写请求删除缓存数据; (2)读请求查询缓存未击中(Hit Miss),紧接着查询数据库,将返回的数据回写到缓存中; (3)写请求更新数据库。...先更新数据库,再删除缓存 如上图的执行过程: (1)读请求先查询缓存缓存未击中,查询数据库返回数据; (2)写请求更新数据库,删除缓存; (3)读请求回写缓存; 整个流程操作下来发现数据库age为20

3.9K20

高并发场景下,到底先更新缓存还是先更新数据库?

踩坑一:先更新数据库,再更新缓存 如果同时有两个写请求需要更新数据,每个写请求都先更新数据库再更新缓存,在并发场景可能会出现数据不一致的情况。...先更新数据库,再更新缓存 如上图的执行过程: (1)写请求1更新数据库,将 age 字段更新为18; (2)写请求2更新数据库,将 age 字段更新为20; (3)写请求2更新缓存缓存 age 设置为...踩坑二:先删缓存,再更新数据库 如果写请求的处理流程是先删缓存更新数据库,在一个读请求和一个写请求并发场景下可能会出现数据不一致情况。...先删缓存,再更新数据库 如上图的执行过程: (1)写请求删除缓存数据; (2)读请求查询缓存未击中(Hit Miss),紧接着查询数据库,将返回的数据回写到缓存中; (3)写请求更新数据库。...先更新数据库,再删除缓存 如上图的执行过程: (1)读请求先查询缓存缓存未击中,查询数据库返回数据; (2)写请求更新数据库,删除缓存; (3)读请求回写缓存; 整个流程操作下来发现数据库age为20

56450

高并发场景下,到底先更新缓存还是先更新数据库?

踩坑一:先更新数据库,再更新缓存 如果同时有两个写请求需要更新数据,每个写请求都先更新数据库再更新缓存,在并发场景可能会出现数据不一致的情况。 ?...先更新数据库,再更新缓存 如上图的执行过程: (1)写请求1更新数据库,将 age 字段更新为18; (2)写请求2更新数据库,将 age 字段更新为20; (3)写请求2更新缓存缓存 age 设置为...踩坑二:先删缓存,再更新数据库 如果写请求的处理流程是先删缓存更新数据库,在一个读请求和一个写请求并发场景下可能会出现数据不一致情况。 ?...先删缓存,再更新数据库 如上图的执行过程: (1)写请求删除缓存数据; (2)读请求查询缓存未击中(Hit Miss),紧接着查询数据库,将返回的数据回写到缓存中; (3)写请求更新数据库。...先更新数据库,再删除缓存 如上图的执行过程: (1)读请求先查询缓存缓存未击中,查询数据库返回数据; (2)写请求更新数据库,删除缓存; (3)读请求回写缓存; 整个流程操作下来发现数据库age为20

67610

数据的呈现和组织,缓存更新

可见,这个map被用作本地的一级缓存,trie是二级缓存,底层数据库是第三级,各级数据结构的界限非常清晰,这样逐级缓存数据,每一级数据向上一级提交的时机也根据业务需求做了合理的选择。...有意思的是,stateObject内部也有类似StateDB一样的二级数据缓存机制,用来缓存更新这些State。 ?...当SetState()调用发生时,storage内部State数据更新,相应标示为"dirty"。...StateDB作为本地存储模块,它面向业务模型,又连接底层数据库,内部利用两极缓存机制来存储和更新所有代表“账户”的stateObject对象。...stateObject除了管理着账户余额等信息之外,也用了类似的两级缓存机制来存储和更新所有的State数据

1.9K70

如何定时更新或者缓存Feed订阅的RSS数据

本站的友链页面,增加显示了部分站长RSS订阅聚合数据。采用的插件是Lopwon Feed。   ...正好网友荒野孤灯遇到了同样的问题,我就索引度娘了一番,查询如何定时的缓存订阅数据,以减少加载时间。不过查出来的一般都是Redis,TPCache之类的。...Redis我熟,是单独的一个类似缓存数据库的东西;而TPCache又是一个插件。我也不想插件套插件了。干脆搜搜网页,弄个最简单的就好了。 建立缓存目录 在网站根目录下,新建了一个文件夹cache。...也是怕自己突然懵了 //缓存目录 - 这里注意上面建立缓存目录的路径 $cacheDir = '....://)','',$link.'.xml.cache')); //缓存时间 1小时 - 下面写秒 $ageInSeconds = 3600; //清除文件状态缓存 clearstatcache(); /

1.4K20

Java项目冷更新数据缓存方案 ( Redis + GuavaCache )

Java项目冷更新数据缓存方案 应用场景 双缓存方案前言 需要考虑的点 1、缓存数据的大小 2、本地缓存缓存时机 3、并发情况下,首次缓存数据的性能浪费问题 4、心跳检测redis是否可用 方案思路...2、本地缓存临时为redis分担压力,缓存热点数据到本地 3、缓存数据一般涉及大量运算,耗时较大,而且不会频繁的更新,多用于计算后进行展示 本人以下方案着重场景1: 本人的项目遇到的问题的是,某个数据展示的接口...而对于后台来说,一共就是10*N的开销,也会有N次的更新缓存操作。而我们知道,实际上更新缓存只需要1次即可,其余N-1次都是没有意义的。并且其余的N-1次的数据计算也是没有意义的。...上述再次举例:(此处有锁机制的情况) 假设无缓存情况下,N个请求并发,数据计算代码耗时10s。 那么: 只有1个线程拥有数据计算和更新缓存的权利,其余N-1个线程会被阻塞,直到缓存更新完毕。...4、本地缓存是否存在, 存在的话直接读数据,结束; 不存在的话,从数据库获取数据进行计算,然后更新本地缓存,返回结果,结束; 可优化的地方有很多,结合上述"需要考虑的点"来优化步骤。 代码 暂不贴

92330

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

◆ 如何更新缓存 更新缓存的步骤特别简单,共两步:更新数据库和更新缓存。但这简单的两步中需要考虑很多问题。 1)先更新数据库还是先更新缓存更新缓存时先删除还是直接更新?...◆ 组合1:先更新缓存,再更新数据库 对于这个组合,会遇到这种情况:假设第二步更新数据库失败了,要求回滚缓存更新,这时该怎么办呢?...2)线程A将缓存中的值更新成b,且保存了原来的值a,然后更新数据库。 3)线程B将缓存中的值更新成c,且保存了原来的值b,然后更新数据库。...◆ 组合5:先删除缓存更新数据库,再删除缓存 还有一个方案,就是先删除缓存,再更新数据库,再删除缓存。...这个方案其实和先更新数据库,再删除缓存差不多,因为还是会出现类似的问题:假设线程A要更新数据库,先删除了缓存,这一瞬间线程C要读缓存,先把数据迁移到缓存;然后线程A完成了更新数据库的操作,这一瞬间线程B

77110

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

如何更新缓存 更新缓存的步骤特别简单,共两步:更新数据库和更新缓存。但这简单的两步中需要考虑很多问题。 1)先更新数据库还是先更新缓存更新缓存时先删除还是直接更新?...组合1:先更新缓存,再更新数据库 对于这个组合,会遇到这种情况:假设第二步更新数据库失败了,要求回滚缓存更新,这时该怎么办呢?...2)线程A将缓存中的值更新成b,且保存了原来的值a,然后更新数据库。 3)线程B将缓存中的值更新成c,且保存了原来的值b,然后更新数据库。...组合5:先删除缓存更新数据库,再删除缓存 还有一个方案,就是先删除缓存,再更新数据库,再删除缓存。...这个方案其实和先更新数据库,再删除缓存差不多,因为还是会出现类似的问题:假设线程A要更新数据库,先删除了缓存,这一瞬间线程C要读缓存,先把数据迁移到缓存;然后线程A完成了更新数据库的操作,这一瞬间线程B

78630
领券