分布式中的缓存更新策略 比较

缓存更新的套路
这个coolshell的文章我看过了两三次,有事没事想起来一下,这几天看了看分布式相关的,又看到了有人谈缓存的更新策略。所以我还是也自己总结一下把。这篇文章前面说的很详细了。但是结尾的那一部分简单的带过了两个更新,其中一个失败的问题。

我这里来列一个各种更新策略的问题吧。

1.先删缓存,再更新数据库

  • case1
    客户端A要写数据,B要读数据
    A先删除了缓存。
    B刚好要读这个数据,先读了缓存,找不到。
    B去数据库里拿到了数据
    B又放进了缓存,此时缓存是旧数据。
    A去写了数据。
    结束,脏数据出来了。
    这样的时序并不难产生,分布式下,A只要有网络延迟或者GC下,都是可能的。
    即使在网络无问题的情况下,这个可能性也是很大的。因为读操作的速度比写快,所以B只要时间点刚好,很大可能有这个问题。

2.先更新数据库,再更新缓存

我自己瞎想的,应该没人这么干

  • case2
    A要写数据,先写缓存。成功
    A还没有来及写数据库,挂了。或者就是单纯的写失败。
    结束,脏数据。

3.先更新数据库,后更新缓存。

  • case3
    A,B都要写那个数据。
    A先来了,先写数据库变成了1,
    B来了,写数据库变成了2,
    B修改缓存的request先到了缓存,变成了2.
    A的反而后到,写缓存变成了1.
    结束,数据库里是2,缓存里是1,脏数据了。
    这个可能性也很大,两步的操作并不是原子操作。

4.先更新数据库,再删除缓存

  • case4
    B要写,A要读。
    A先到了,发现缓存里没有
    A去数据库里读到了数据1
    B到了要写数据库,修改成了2
    B去缓存尝试删掉原来1的缓存,发现没有就不操作。
    A设置缓存的request刚到,把缓存设置了1
    结束,缓存是1,数据库是2,又脏数据了。
    考虑网络延迟,刚好把B的更新缓存卡在了最后一步,这个是很可能发生的。
    再不考虑网络的情况下。B的读操作,完成比较快,A写的慢,所以发生概率较小。

比较case3和case4

再coolshell里面聊到了case4要比case3发生的概率小。我觉得不尽然,

  1. 从导致乱序所延迟的时间来说,两者其实都一样。
    对于case3. A写完数据库瞬间---->写缓存的request到达,延迟:B写一个数据+B写一个缓存。
    对于case4. A读完数据库瞬间----->写缓存的request到达,延迟:B写一个数据+B删一个缓存。
    所以两个case的延迟时间是差不多得(对于缓存的写和删差距差距应该不会大)。
  2. 发生的条件,其实也是相似。
    对于case3. A,B都来写,A写完B写,都是写操作所以要加锁,真个是transaction的,在发生乱序之前是很正常的状态,顺序写数据库吗。
    对于case4,A来数据库,完成了,然后B来写。在发生乱序前也是很正常的事情。
    从A操作数据库完成那一刻,两个的缓存操作都要被延迟了相等的时间,就会发生上面说的那种脏数据。所以case3 和 case4的发生条件基本相同。

唯一一点case4比case3小概率的是:case4要求没有缓存存在。对于一个好的缓存系统,你得命中个50%吧?那其实低就只定在这个情况上呗。降低的概率也是肉眼可见的,不是说极其罕见的。只要case3的问题敢发生,那case4的也大概率会发生。我估计我没有哪里推理错吧。。

其中一步失败的情况。

https://blog.csdn.net/u012129558/article/details/52278091
这个文章说了先删缓存还是先更新数据库。结论是先删缓存。
原因:
先更新数据库的话,如果第二部更新缓存失败,那就是脏数据。反过来,只是会导致下次缓存不命中。
博主以先删缓存的为基础,尝试保证数据库操作的严格串行,最后整到了让对一个data落到同一个service上面。其实即使做到了,也依然不能通过case1的问题,因为两个不是原子操作,并不能保证AB去操作数据库的顺序,即使能保证先到的先完成。
不过这个解决思路是对同一个数据的修改落到同一个service上,那这样的话其实缓存也不存在分布式问题了,因为同一个数据的缓存就只有一个service来串行修改啦,想怎么弄,怎么弄。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 159,835评论 4 364
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,598评论 1 295
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 109,569评论 0 244
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,159评论 0 213
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,533评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,710评论 1 222
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,923评论 2 313
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,674评论 0 203
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,421评论 1 246
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,622评论 2 245
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,115评论 1 260
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,428评论 2 254
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,114评论 3 238
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,097评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,875评论 0 197
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,753评论 2 276
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,649评论 2 271