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

Redis的緩存更新策略及最佳實踐方案

 更新時間:2023年08月10日 10:31:40   作者:程序員阿紅  
這篇文章主要介紹了Redis的緩存更新策略及最佳實踐方案,當(dāng)我們向redis插入太多數(shù)據(jù),此時就可能會導(dǎo)致緩存中的數(shù)據(jù)過多,所以redis會對部分?jǐn)?shù)據(jù)進(jìn)行更新,或者把它成為淘汰更合適,需要的朋友可以參考下

緩存更新

緩存的更新是redis為了節(jié)約內(nèi)存而設(shè)計出來的東西,主要是因為內(nèi)存數(shù)據(jù)寶貴,當(dāng)我們向redis插入太多數(shù)據(jù),此時就可能會導(dǎo)致緩存中的數(shù)據(jù)過多,所以redis會對部分?jǐn)?shù)據(jù)進(jìn)行更新,或者把它成為淘汰更合適。

1.redis的緩存更新的三種策略

  1. 內(nèi)存淘汰
    • redis自動進(jìn)行,當(dāng)redis內(nèi)存達(dá)到咱們設(shè)定的max-memery的時候會自動觸發(fā)淘汰機制,淘汰調(diào)一些不重要的數(shù)據(jù)(自己可以設(shè)置策略方式)
  2. 超時剔除
    • 當(dāng)我們給redis設(shè)置了過期時間ttl之后,redis會將超時的數(shù)據(jù)進(jìn)行刪除,方便咱們繼續(xù)使用緩存。
  3. 主動更新
    • 我們可以手動條用方法把緩存刪掉,通常用于解決緩存和數(shù)據(jù)庫不一致問題。

主動更新有分三種方式:

  1. 由緩存的調(diào)用者,在更新數(shù)據(jù)庫的同時更新緩存。
  2. 緩存和數(shù)據(jù)庫整合為一個服務(wù),由服務(wù)來維護(hù)一致性。調(diào)用者調(diào)用該服務(wù)(對外提供一個透明的服務(wù)),無需關(guān)系緩存一致性問題。
  3. 調(diào)用者只操作緩存,有其他線程異步的將緩存持久化到數(shù)據(jù)庫,保證最終一致。(類似于數(shù)據(jù)庫的索引,一個索引更新在沒有提交事務(wù)時,修改了100次只有最后一次有效,但這會使效率降低。)

如果采用第一個方案,那么假設(shè)我們每次操作數(shù)據(jù)庫后,都操作緩存,但是中間如果沒有人查詢,那么這個更新動作實際上只有最后一次生效,中間的更新動作意義并不大,我們可以把緩存刪除,等待再次查詢時,將緩存中的數(shù)據(jù)加載出來

  • 刪除緩存還是更新緩存?
    • 更新緩存:每次更新數(shù)據(jù)庫都更新緩存,無效寫操作較多
    • 刪除緩存:更新數(shù)據(jù)庫時讓緩存失效,查詢時再更新緩存
  • 如何保證緩存與數(shù)據(jù)庫的操作的同時成功或失???
    • 單體系統(tǒng),將緩存與數(shù)據(jù)庫操作放在一個事務(wù)
    • 分布式系統(tǒng),利用TCC等分布式事務(wù)方案
  • 先操作緩存還是先操作數(shù)據(jù)庫?
    • 先刪除緩存,再操作數(shù)據(jù)庫 (第一種方案)
    • 先操作數(shù)據(jù)庫,再刪除緩存

應(yīng)該具體操作緩存還是操作數(shù)據(jù)庫,我們應(yīng)當(dāng)是先操作數(shù)據(jù)庫,再刪除緩存,原因在于,如果你選擇第一種方案,在兩個線程并發(fā)來訪問時,假設(shè)線程1先來,他先把緩存刪了,此時線程2過來,他查詢緩存數(shù)據(jù)并不存在,此時他寫入緩存,當(dāng)他寫入緩存后,線程1再執(zhí)行更新動作時,實際上寫入的就是舊的數(shù)據(jù),新的數(shù)據(jù)被舊數(shù)據(jù)覆蓋了。

image-20221206204151058

redis的讀寫是微秒級別的,但是數(shù)據(jù)庫的更新時遠(yuǎn)遠(yuǎn)比redis的讀寫慢的。

三者之間比較

image-20221206195626851

2. 緩存更新策略的最佳實踐方案:

  1. 低一致性需求:使用Redis自帶的內(nèi)存淘汰機制
  2. 高一致性需求:主動更新,并以超時剔除作為兜底方案
  • 讀操作:
    • 緩存命中則直接返回
    • 緩存未命中則查詢數(shù)據(jù)庫,并寫入緩存,設(shè)定超時時間
  • 寫操作:
    • 先寫數(shù)據(jù)庫,然后再刪除緩存
    • 要確保數(shù)據(jù)庫與緩存操作的原子性

到此這篇關(guān)于Redis的緩存更新策略及最佳實踐方案的文章就介紹到這了,更多相關(guān)Redis緩存更新策略內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • redis?設(shè)置生存和過期時間的原理分析

    redis?設(shè)置生存和過期時間的原理分析

    這篇文章主要介紹了redis?設(shè)置生存和過期時間的原理,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • Redis?HyperLogLog數(shù)據(jù)統(tǒng)計輕量級解決方案詳解

    Redis?HyperLogLog數(shù)據(jù)統(tǒng)計輕量級解決方案詳解

    這篇文章主要為大家介紹了Redis?HyperLogLog數(shù)據(jù)統(tǒng)計輕量級解決方案詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-12-12
  • Redis優(yōu)化token校驗主動失效的實現(xiàn)方案

    Redis優(yōu)化token校驗主動失效的實現(xiàn)方案

    在普通的token頒發(fā)和校驗中 當(dāng)用戶發(fā)現(xiàn)自己賬號和密碼被暴露了時修改了登錄密碼后舊的token仍然可以通過系統(tǒng)校驗直至token到達(dá)失效時間,所以系統(tǒng)需要token主動失效的一種能力,所以本文給大家介紹了Redis優(yōu)化token校驗主動失效的實現(xiàn)方案,需要的朋友可以參考下
    2024-03-03
  • Redis獲取某個前綴的key腳本實例

    Redis獲取某個前綴的key腳本實例

    這篇文章主要給大家介紹了關(guān)于Redis獲取某個前綴的key腳本的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用Redis具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。
    2018-04-04
  • 利用Redis實現(xiàn)訂單30分鐘自動取消

    利用Redis實現(xiàn)訂單30分鐘自動取消

    本文主要介紹了利用Redis實現(xiàn)訂單30分鐘自動取消,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-06-06
  • Unable?to?connect?to?Redis無法連接到Redis解決的全過程

    Unable?to?connect?to?Redis無法連接到Redis解決的全過程

    這篇文章主要給大家介紹了關(guān)于Unable?to?connect?to?Redis無法連接到Redis解決的相關(guān)資料,文中通過圖文以及實例代碼將解決的過程介紹的非常詳細(xì),需要的朋友可以參考下
    2023-03-03
  • 關(guān)于Redis網(wǎng)絡(luò)模型的源碼詳析

    關(guān)于Redis網(wǎng)絡(luò)模型的源碼詳析

    這篇文章主要給大家介紹了關(guān)于Redis網(wǎng)絡(luò)模型的源碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者使用Redis具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-07-07
  • Redis線程模型的原理分析

    Redis線程模型的原理分析

    Redis是一個高性能的數(shù)據(jù)存儲框架,在高并發(fā)的系統(tǒng)設(shè)計中,Redis也是一個比較關(guān)鍵的組件,是我們提升系統(tǒng)性能的一大利器,本文詳細(xì)的介紹了Redis線程模型,感興趣的可以了解一
    2021-11-11
  • redis輕松處理經(jīng)緯度坐標(biāo)點數(shù)據(jù)的實現(xiàn)方法

    redis輕松處理經(jīng)緯度坐標(biāo)點數(shù)據(jù)的實現(xiàn)方法

    這篇文章主要介紹了redis輕松處理經(jīng)緯度坐標(biāo)點數(shù)據(jù)的實現(xiàn)方法,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-10-10
  • 從源碼解讀redis持久化

    從源碼解讀redis持久化

    redis的持久化也就是數(shù)據(jù)落地,對于任何一個數(shù)據(jù)系統(tǒng)都要考慮是不是需要數(shù)據(jù)落地。在系統(tǒng)崩潰或是機房掉電等的情況下,將有用的數(shù)據(jù)記錄在非易失性存儲器上面,防止數(shù)據(jù)丟失,以及用來系統(tǒng)重啟時的數(shù)據(jù)恢復(fù)。
    2018-08-08

最新評論