欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

redis延遲雙刪策略示例講解

 更新時(shí)間:2023年04月14日 11:24:14   作者:每一天,為明天,go  
延遲是指當(dāng)前請求邏輯處理延時(shí),而不是當(dāng)前線程或進(jìn)程睡眠延遲,下面這篇文章主要給大家介紹了關(guān)于redis延遲雙刪策略的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下

在當(dāng)前環(huán)境下,通常我們會(huì)首選redis緩存來減輕我們數(shù)據(jù)庫訪問壓力。但是也會(huì)遇到以下這種情況:大量用戶來訪問我們系統(tǒng),首先會(huì)去查詢緩存, 如果緩存中沒有數(shù)據(jù),則去查詢數(shù)據(jù)庫,然后更新數(shù)據(jù)到緩存中,并且如果數(shù)據(jù)庫中的數(shù)據(jù)發(fā)生了改變則需要同步到redis中,同步過程中需要保證 MySQL與redis數(shù)據(jù)一致性問題,在這個(gè)同步過程中出現(xiàn)短暫的數(shù)據(jù)延遲也是正?,F(xiàn)象,但是最終需要保證mysql與緩存中的一致性。

//我們通常使用redis的邏輯
    //通常我們是先查詢r(jià)eids
    String value = RedisUtils.get(key);
    if (!StringUtils.isEmpty(value)){
        return value;
    }
//從數(shù)據(jù)庫中獲取數(shù)據(jù)
    value = getValueForDb(key);
    if (!StringUtils.isEmpty(value)){
           RedisUtils.set(key,value);
        return value;
     }

1、什么是延遲雙刪?

延遲雙刪策略是分布式系統(tǒng)中數(shù)據(jù)庫存儲(chǔ)和緩存數(shù)據(jù)保持一致性的常用策略,但它不是強(qiáng)一致。其實(shí)不管哪種方案,都避免不了Redis存在臟數(shù)據(jù)的問題,只能減輕這個(gè)問題,要想徹底解決,得要用到同步鎖和對應(yīng)的業(yè)務(wù)邏輯層面解決。

2、為什么要進(jìn)行延遲雙刪?

一般我們在更新數(shù)據(jù)庫數(shù)據(jù)時(shí),需要同步redis中緩存的數(shù)據(jù) 所以我們一般會(huì)給出兩種方案:

  • 第一種方案:先執(zhí)行update操作,再執(zhí)行緩存清除。
  • 第二種方案:先執(zhí)行緩存清除,再執(zhí)行update操作。

但是這兩種方案在并發(fā)請求中容易出現(xiàn)以下問題

第一種方案弊端:當(dāng)請求1去執(zhí)行數(shù)據(jù)庫更新操作之后,還沒執(zhí)行緩存清除時(shí),請求2就進(jìn)來了查詢了緩存,此時(shí)緩存中數(shù)據(jù)還是舊數(shù)據(jù),還沒來得機(jī)刪除導(dǎo)致數(shù)據(jù)出現(xiàn)問題,但是當(dāng)t1執(zhí)行緩存刪除操作之后,后面的請求查詢不到緩存,再到數(shù)據(jù)中查詢,然后更新到緩存中,這種影響是比較小的

  1. t1線程 先更新db;
  2. t2線程查詢命中緩存 返回舊的數(shù)據(jù);
  3. 假設(shè)t1線程更新完db,預(yù)計(jì)5毫秒刪除完緩存key 在5毫秒內(nèi) 其他線程查詢緩存結(jié)果還是為舊的數(shù)據(jù),但是 5毫秒后查詢緩存結(jié)果是為空,在從新將db最新的結(jié)果同步到Redis中。
  4. 一個(gè)項(xiàng)目中出現(xiàn)延遲是非常正常的,所以該情況發(fā)生的延遲對業(yè)務(wù)的影響其實(shí)很小。但是如果發(fā)生了,刪除緩存失敗呢?

1.不斷重試----如果是在http協(xié)議接口中 會(huì)導(dǎo)致接口響應(yīng)變慢 調(diào)用該接口 會(huì)發(fā)生響應(yīng)超時(shí) 2.或者通過mq異步的形式同步

第二種方案弊端:當(dāng)請求1執(zhí)行清除緩存后,還未執(zhí)行數(shù)據(jù)更新操作的時(shí),請求2進(jìn)來查詢到數(shù)據(jù)庫的舊數(shù)據(jù),并寫入了redis,這就導(dǎo)致了數(shù)據(jù)庫與redis數(shù)據(jù)不一致問題。

  • t1線程先刪除緩存;
  • t2線程讀取緩存為null,同步db數(shù)據(jù)到緩存中;
  • t1線程更新db中的數(shù)據(jù);
  • t3線程查詢緩存中數(shù)據(jù)是舊數(shù)據(jù);

3、對于方案處理都有弊端,那么我們需要使用延遲雙刪策略

先進(jìn)行緩存清除,再執(zhí)行update,最后(延遲N秒)再執(zhí)行緩存清除。進(jìn)行兩次刪除,且中間需要延遲一段時(shí)間

    RedisUtils.del(key);// 先刪除緩存    updateDB(user);// 更新db中的數(shù)據(jù)    Thread.sleep(N);// 延遲一段時(shí)間,在刪除該緩存key    RedisUtils.del(key);// 先刪除緩存

4、需要注意的點(diǎn)

上述中(延遲N秒)的時(shí)間要大于一次寫操作的時(shí)間。原因:如果延遲時(shí)間小于寫入redis的時(shí)間,會(huì)導(dǎo)致請求1清除了緩存,但是請求2緩存還未寫入的尷尬。。。

5、延遲的時(shí)間如何確定?

在業(yè)務(wù)程序運(yùn)行時(shí),統(tǒng)計(jì)業(yè)務(wù)邏輯執(zhí)行讀數(shù)據(jù)和寫緩存的操作時(shí)間,以此為基礎(chǔ)來進(jìn)行估算。因?yàn)檫@個(gè)方案會(huì)在第一次刪除緩存值后,延遲一段時(shí)間再次進(jìn)行刪除,所以稱為“延遲雙刪”。

小結(jié)

延遲雙刪策略只是一種同步數(shù)據(jù)庫與緩存的手段,在系統(tǒng)并發(fā)量不高的情況下可以使用這種方式解決,如果是并發(fā)量高的情況下我們也可以另尋其他解決方案 如:canal

到此這篇關(guān)于redis延遲雙刪策略的文章就介紹到這了,更多相關(guān)redis延遲雙刪策略內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Windows安裝Redis并添加本地自啟動(dòng)服務(wù)的實(shí)例詳解

    Windows安裝Redis并添加本地自啟動(dòng)服務(wù)的實(shí)例詳解

    這篇文章主要介紹了Windows安裝Redis并添加本地自啟動(dòng)服務(wù)的實(shí)例詳解,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-11-11
  • 詳解如何清理redis集群的所有數(shù)據(jù)

    詳解如何清理redis集群的所有數(shù)據(jù)

    這篇文章主要介紹了詳解如何清理redis集群的所有數(shù)據(jù),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-02-02
  • Redis秒殺實(shí)現(xiàn)方案講解

    Redis秒殺實(shí)現(xiàn)方案講解

    這篇文章主要介紹了Redis秒殺實(shí)現(xiàn)方案,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧
    2022-12-12
  • 在K8s上部署Redis集群的方法步驟

    在K8s上部署Redis集群的方法步驟

    這篇文章主要介紹了在K8s上部署Redis集群的方法步驟,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-04-04
  • Redis 中的布隆過濾器的實(shí)現(xiàn)

    Redis 中的布隆過濾器的實(shí)現(xiàn)

    這篇文章主要介紹了Redis 中的布隆過濾器的實(shí)現(xiàn),詳細(xì)的介紹了什么是布隆過濾器以及如何實(shí)現(xiàn),非常具有實(shí)用價(jià)值,需要的朋友可以參考下
    2018-10-10
  • windows下使用redis requirepass認(rèn)證不起作用的解決方法

    windows下使用redis requirepass認(rèn)證不起作用的解決方法

    今天小編就為大家分享一篇windows下使用redis requirepass認(rèn)證不起作用的解決方法,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-05-05
  • Redis?key的過期時(shí)間和永久有效的實(shí)現(xiàn)

    Redis?key的過期時(shí)間和永久有效的實(shí)現(xiàn)

    在Redis中,鍵可以設(shè)置過期時(shí)間或被永久保存,`EXPIRE`和`PEXPIRE`命令分別用于設(shè)置鍵的過期時(shí)間,具有一定的參考價(jià)值,感興趣的可以了解一下
    2024-09-09
  • Redis中三種特殊數(shù)據(jù)類型命令詳解

    Redis中三種特殊數(shù)據(jù)類型命令詳解

    Geospatial是地理位置類型,我們可以用來查詢附近的人、計(jì)算兩人之間的距離等,這篇文章主要介紹了Redis中三種特殊數(shù)據(jù)類型命令詳解,需要的朋友可以參考下
    2024-05-05
  • 如何利用 Redis 實(shí)現(xiàn)接口頻次限制

    如何利用 Redis 實(shí)現(xiàn)接口頻次限制

    這篇文章主要介紹了如何利用 Redis 實(shí)現(xiàn)接口頻次限制,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-02-02
  • Redis解決庫存超賣問題實(shí)例講解

    Redis解決庫存超賣問題實(shí)例講解

    這篇文章主要介紹了Redis解決庫存超賣問題實(shí)例講解,問題和解決辦法都列舉了出來,很貼合實(shí)際開發(fā)場景,有需要的同學(xué)可以學(xué)習(xí)下
    2021-03-03

最新評論