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

Redis 緩存雙寫一致性的解決方案

 更新時(shí)間:2025年02月28日 10:06:57   作者:為什么要做囚徒  
本文主要介紹了Redis 緩存雙寫一致性的解決方案,包括CacheAsidePattern、ReadThrough/WriteThrough和WriteBehind三種模式,具有一定的參考價(jià)值,感興趣的可以了解一下

1. 什么叫做緩存雙寫一致性?

Redis緩存雙寫一致性是指在更新數(shù)據(jù)庫數(shù)據(jù)后,同時(shí)更新緩存數(shù)據(jù)以保持?jǐn)?shù)據(jù)一致性的策略,總的來說,就是寫入redis寫入數(shù)據(jù)庫的數(shù)據(jù)要保持一致

2. 緩存雙寫一致性有那些解決方案?

2.1 Cache Aside Pattern(旁路緩存模式)

旁路緩存模式,字面意思理解:緩存是旁路,緩存相對與應(yīng)用程序和數(shù)據(jù)庫是旁路,應(yīng)用程序可以直接繞過緩存訪問數(shù)據(jù)庫

在Cache Aside模式中,應(yīng)用程序首先從緩存中讀取數(shù)據(jù),如果緩存中不存在,則從數(shù)據(jù)庫中讀取數(shù)據(jù),并將數(shù)據(jù)寫入緩存中。在更新數(shù)據(jù)時(shí),應(yīng)用程序首先更新數(shù)據(jù)庫中的數(shù)據(jù),然后刪除緩存中的數(shù)據(jù)。當(dāng)下一次請求到來時(shí),應(yīng)用程序會從數(shù)據(jù)庫中讀取最新的數(shù)據(jù),并將其寫入緩存中

那為什么要先更新數(shù)據(jù)庫在刪除緩存了?我們再看看幾種更新策略

策略是否是多線程場景現(xiàn)象
先刪除緩存再更新數(shù)據(jù)庫刪除緩存成功但數(shù)據(jù)庫更新失敗應(yīng)用程序從數(shù)據(jù)庫中讀到舊值
緩存刪除成功但數(shù)據(jù)庫再更新中…有并發(fā)讀請求并發(fā)讀請求從數(shù)據(jù)庫讀到舊值,并回寫到redis,導(dǎo)致后續(xù)都從redis讀取到舊值
先更新數(shù)據(jù)庫再刪除緩存數(shù)據(jù)庫更新成功,但緩存刪除失敗應(yīng)用程序從redis讀取到舊值
數(shù)據(jù)庫更新成功,但緩存再刪除中…有并發(fā)讀請求并發(fā)讀請求讀取到舊值
先更新緩存再更新數(shù)據(jù)庫更新緩存成功但更新數(shù)據(jù)庫失敗緩存和數(shù)據(jù)庫數(shù)據(jù)不一致(不推薦,一般數(shù)據(jù)庫作為兜底方案)
更新緩存成功但數(shù)據(jù)庫再更新中緩存和數(shù)據(jù)庫數(shù)據(jù)不一致(不推薦,一般數(shù)據(jù)庫作為兜底方案)
先更新數(shù)據(jù)庫再更新緩存更新數(shù)據(jù)庫成功但緩存更新失敗應(yīng)用程序讀取到舊值
更新數(shù)據(jù)庫成功但緩存再更新中…有并發(fā)讀請求并發(fā)讀請求讀取到舊值

延遲雙刪

經(jīng)過我們對Cache Aside Pattern四種方案的八種場景進(jìn)行仔細(xì)分析,我們大體上確定了先更數(shù)據(jù)庫再刪緩存的方案。但是這種方案也并不完美,假設(shè)我們更新數(shù)據(jù)庫成功了,刪除緩存失敗了,那么同樣會出現(xiàn)一致性問題。為了解決這種場景下的一致性問題,我們進(jìn)一步引入了延遲雙刪方案來解決。

  • 為什么要做兩次緩存刪除呢?

從上圖“延遲雙刪”中我們可以很清晰地看到,數(shù)據(jù)庫的更新是在首次的緩存刪除成功后進(jìn)行的,這樣就有效避地免了“先更數(shù)據(jù)庫再刪緩存”方案中可能出現(xiàn)的數(shù)據(jù)庫更新成功緩存刪除失敗導(dǎo)致的一致性問題。第二次的緩存刪除是為了避免在執(zhí)行更新數(shù)據(jù)庫操作完成之前其它線程讀取數(shù)據(jù)庫并更新緩存而導(dǎo)致的一致性問題。

  • 為什么第二次緩存刪除又要延遲執(zhí)行呢?

試想,如果我們不做第二次的延遲刪除,而是更新數(shù)據(jù)庫后立即刪除會出什么問題?有沒有可能其它讀請求線程在更新數(shù)據(jù)庫之前讀取了數(shù)據(jù),并在第二次立即刪除緩存之后更新了緩存。很明顯,延遲刪除就是為了讓可能存在的其它讀請求線程盡可能地在更新完緩存后再執(zhí)行緩存刪除操作。這樣一通操作后,數(shù)據(jù)庫是最新的數(shù)據(jù)了,緩存里沒有數(shù)據(jù),后面的讀請求線程又可以拿到數(shù)據(jù)庫的最新數(shù)據(jù)寫入緩存了。

  • 延遲刪除具體需要延遲多長時(shí)間?

對于這個(gè)具體需要延遲多長時(shí)間,其實(shí)沒有絕對的標(biāo)準(zhǔn),唯一的標(biāo)準(zhǔn)就是根據(jù)讀請求的耗時(shí)來確定,讀請求越耗時(shí),延遲時(shí)間越長。一般情況下我們設(shè)置的延遲時(shí)間為1秒。

重試刪除

在上面的延遲雙刪方案中,如果我們思考,其實(shí)還是有諸多問題的。比如:在延遲雙刪的讀寫場景中,如果第二次緩存刪除失敗了,同樣會出現(xiàn)一致性問題。那么刪除失敗了,重試幾次不就好了嗎?基于這個(gè)思想我們進(jìn)一步引入了重試刪除方案來解決

重試刪除確實(shí)很大程度上解決了一致性問題,并且邏輯非常簡單。唯一的不足可能就是需要引入消息隊(duì)列,并且業(yè)務(wù)代碼也會有一定的侵入。那么有沒有既能夠保證最終一致性,又能夠解耦的方案呢?我們繼續(xù)往下面看

binlog訂閱異步刪除

binlog訂閱異步刪除確實(shí)也能解決一致性問題,對代碼也無任何侵入,但是整個(gè)架構(gòu)復(fù)雜,中小項(xiàng)目一般都用不上。

2.2 Read Through/Write Through(讀寫穿透)

該策略又被稱為讀穿/寫穿策略,和CacheAside策略的緩存數(shù)據(jù)與數(shù)據(jù)庫數(shù)據(jù)為準(zhǔn)不同,該策略的核心是用戶只與緩存層交互(應(yīng)用程序只與緩存或者中間層、緩存抽象層交互),由緩存層與數(shù)據(jù)庫通信,寫入或讀取數(shù)據(jù)。

在讀取數(shù)據(jù)時(shí),通過緩存層進(jìn)行讀取,若緩存存在則直接返回,若不存在則由緩存層拉取數(shù)據(jù)庫數(shù)據(jù)到緩存中并返回。
在寫數(shù)據(jù)時(shí),通過緩存層進(jìn)行寫入,若緩存存在則直接寫入緩存中并同步到數(shù)據(jù)庫,若不存在則寫入數(shù)據(jù)庫中。

使用場景

適用于讀多寫多的場景,數(shù)據(jù)一致性要求較高的場景。

2.3 Write Behind(后寫或異步寫)

Write Behind Caching是一種將緩存和數(shù)據(jù)庫異步寫入的緩存模式。在Write Behind Caching模式中,應(yīng)用程序首先將更新操作寫入緩存中,然后異步地將更新操作寫入數(shù)據(jù)庫中。當(dāng)下一次請求到來時(shí),應(yīng)用程序會從緩存中讀取數(shù)據(jù),并將其寫入數(shù)據(jù)庫中。

使用場景

適用于寫多讀少的場景,數(shù)據(jù)一致性要求不高的場景

3. 總結(jié)

在使用Redis緩存時(shí),應(yīng)根據(jù)具體的業(yè)務(wù)場景和需求選擇合適的緩存模式。Cache Aside模式簡單易用,適用于讀多寫少的場景;Read/Write Through模式完全解耦緩存和數(shù)據(jù)庫,適用于讀多寫多的場景;Write Behind Caching模式可以提高寫入性能,適用于寫多讀少的場景。在實(shí)際應(yīng)用中,可以根據(jù)具體的業(yè)務(wù)需求和性能要求,選擇合適的緩存模式,以提高系統(tǒng)的性能和穩(wěn)定性。

到此這篇關(guān)于Redis 緩存雙寫一致性的實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)Redis 緩存雙寫一致性內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 詳解三分鐘快速搭建分布式高可用的Redis集群

    詳解三分鐘快速搭建分布式高可用的Redis集群

    這篇文章主要介紹了詳解三分鐘快速搭建分布式高可用的Redis集群,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-02-02
  • redis禁止幾個(gè)危險(xiǎn)命令的方法

    redis禁止幾個(gè)危險(xiǎn)命令的方法

    今天小編就為大家分享一篇redis禁止幾個(gè)危險(xiǎn)命令的方法,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-05-05
  • Redis的KEYS 命令千萬不能亂用

    Redis的KEYS 命令千萬不能亂用

    這篇文章主要介紹了Redis的KEYS 命令千萬不能亂用,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-07-07
  • redis主從連接不成功錯(cuò)誤問題及解決

    redis主從連接不成功錯(cuò)誤問題及解決

    這篇文章主要介紹了redis主從連接不成功錯(cuò)誤問題及解決方案,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教<BR>
    2024-01-01
  • 一文詳解如何使用Redis實(shí)現(xiàn)分布式鎖

    一文詳解如何使用Redis實(shí)現(xiàn)分布式鎖

    這篇文章主要介紹了一文詳解如何使用Redis實(shí)現(xiàn)分布式鎖,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下
    2022-09-09
  • redis4.0入門小結(jié)

    redis4.0入門小結(jié)

    這篇文章主要介紹了redis4.0入門小結(jié),文中通過示例和概念介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2018-11-11
  • redis啟動(dòng)和退出命令行簡單操作步驟

    redis啟動(dòng)和退出命令行簡單操作步驟

    Redis是一種鍵值存儲數(shù)據(jù)庫,用戶可以使用它來存儲和檢索大量的鍵值數(shù)據(jù),下面這篇文章主要給大家介紹了關(guān)于redis啟動(dòng)和退出命令行的相關(guān)資料,需要的朋友可以參考下
    2024-03-03
  • 使用rpm包安裝redis的方法

    使用rpm包安裝redis的方法

    Redis是一款高性能的Key-Value數(shù)據(jù)庫,其開源免費(fèi)且具有高可用性等,本文主要介紹了使用rpm包安裝redis的方法,具有一定的參考價(jià)值,感興趣的可以了解一下
    2023-09-09
  • Redis2.8配置文件中文詳解

    Redis2.8配置文件中文詳解

    這篇文章主要介紹了Redis2.8配置文件中文詳解,本文提供的是是Redis2.8.9的配置文件各項(xiàng)的中文解釋,需要的朋友可以參考下
    2015-06-06
  • 淺析redis cluster介紹與gossip協(xié)議

    淺析redis cluster介紹與gossip協(xié)議

    這篇文章主要介紹了redis cluster介紹與gossip協(xié)議,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-09-09

最新評論