校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > Redis緩存常用4種策略原理詳解

Redis緩存常用4種策略原理詳解

熱門標(biāo)簽:400電話辦理的口碑 地圖標(biāo)注工廠入駐 b2b外呼系統(tǒng) 臺灣電銷 四川穩(wěn)定外呼系統(tǒng)軟件 一個地圖標(biāo)注多少錢 南京手機外呼系統(tǒng)廠家 廊坊外呼系統(tǒng)在哪買 高碑店市地圖標(biāo)注app

我們都知道,提高系統(tǒng)性能的最簡單也最流行的方法之一其實就是使用緩存。我們引入緩存,相當(dāng)于對數(shù)據(jù)進(jìn)行了復(fù)制。每當(dāng)系統(tǒng)數(shù)據(jù)更新時,保持緩存和數(shù)據(jù)源(如 MySQL 數(shù)據(jù)庫)同步至關(guān)重要,當(dāng)然,這也取決于系統(tǒng)本身的要求,看系統(tǒng)是否允許一定的數(shù)據(jù)延遲。

最常見的幾種緩存策略、它們的優(yōu)缺點以及使用場景,分別是:

  • Cache-Aside
  • Read-Through
  • Write-Through
  • Write-Behind

Cache-Aside 策略

Cache-Aside可能是最常用的緩存策略。在這種策略下,應(yīng)用程序(Application)會與緩存(Cache)和數(shù)據(jù)源(Data Source)進(jìn)行通信,應(yīng)用程序會在命中數(shù)據(jù)源之前先檢查緩存。如下圖所示:

我們來看一次請求數(shù)據(jù)的過程:

  • 首先,應(yīng)用程序先確定數(shù)據(jù)是否保留在緩存中;
  • 如果數(shù)據(jù)在緩存中,也即 Cache hit ,稱作“緩存命中”。數(shù)據(jù)直接從緩存中讀取并返回給客戶端應(yīng)用程序;
  • 如果數(shù)據(jù)不在緩存中,也即 Cache miss,稱作“緩存未命中”。應(yīng)用程序會從數(shù)據(jù)存儲的地方,如 MySQL 數(shù)據(jù)源中讀取該數(shù)據(jù),并將數(shù)據(jù)存儲在緩存中,然后將其返回給客戶端。

Cache-Aside策略特別適合“讀多”的應(yīng)用場景。使用Cache Aside策略的系統(tǒng)可以在一定程度上抵抗緩存故障。如果緩存服務(wù)發(fā)生故障,系統(tǒng)仍然可以通過直接訪問數(shù)據(jù)庫進(jìn)行操作。

然而,這種策略并不能保證數(shù)據(jù)存儲和緩存之間的一致性,需要配合使用其它策略來更新或使緩存無效。另外,首次請求數(shù)據(jù)時,總是會導(dǎo)致緩存未命中,這種情況下需要額外的時間來將數(shù)據(jù)加載到緩存中。為了解決這個問題,開發(fā)人員可以通過手動觸發(fā)查詢操作來對數(shù)據(jù)進(jìn)行“預(yù)熱”。

Read-Through 策略

在上面的Cache-Aside策略中,應(yīng)用程序需要與緩存和數(shù)據(jù)源“打交道”,而在Read-Through策略下,應(yīng)用程序無需管理數(shù)據(jù)源和緩存,只需要將數(shù)據(jù)源的同步委托給緩存提供程序Cache Provider即可。所有數(shù)據(jù)交互都是通過抽象緩存層完成的。

在進(jìn)行大量讀取時,Read-Through可以減少數(shù)據(jù)源上的負(fù)載,也對緩存服務(wù)的故障具備一定的彈性。如果緩存服務(wù)掛了,則緩存提供程序仍然可以通過直接轉(zhuǎn)到數(shù)據(jù)源來進(jìn)行操作。

然而,首次請求數(shù)據(jù)時,總是會導(dǎo)致緩存未命中,并需要額外的時間來將數(shù)據(jù)加載到緩存中,相信大家都知道怎么處理了吧,還是“緩存預(yù)熱”的老套路。

Read-Through適用于多次請求相同數(shù)據(jù)的場景。這與Cache-Aside策略非常相似,但是二者還是存在一些差別,這里再次強調(diào)一下:

  • 在Cache-Aside中,應(yīng)用程序負(fù)責(zé)從數(shù)據(jù)源中獲取數(shù)據(jù)并更新到緩存。
  • 而在Read-Through中,此邏輯通常是由獨立的緩存提供程序支持。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • 聊一聊Redis與MySQL雙寫一致性如何保證
  • MySQL與Redis如何保證數(shù)據(jù)一致性詳解
  • 詳解redis緩存與數(shù)據(jù)庫一致性問題解決
  • redis實現(xiàn)分布式的方法總結(jié)
  • 面試常問:如何保證Redis緩存和數(shù)據(jù)庫的數(shù)據(jù)一致性

標(biāo)簽:伊春 泰州 畢節(jié) 河源 定州 南寧 拉薩 甘南

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Redis緩存常用4種策略原理詳解》,本文關(guān)鍵詞  Redis,緩存,常用,4種,策略,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Redis緩存常用4種策略原理詳解》相關(guān)的同類信息!
  • 本頁收集關(guān)于Redis緩存常用4種策略原理詳解的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 南汇区| 黑河市| 蒲江县| 胶南市| 宁安市| 株洲市| 罗城| 盐边县| 沈阳市| 贵南县| 沾化县| 九江市| 武宁县| 连南| 望城县| 双牌县| 莲花县| 蓝田县| 台南县| 武川县| 闽清县| 当雄县| 上饶市| 苍溪县| 道孚县| 新沂市| 揭东县| 马尔康县| 湖南省| 布拖县| 新津县| 会东县| 凭祥市| 沙河市| 南靖县| 大荔县| 樟树市| 弋阳县| 漳浦县| 芦溪县| 平安县|