Redis緩存常用4種策略原理詳解
我們都知道,提高系統(tǒng)性能的最簡單也最流行的方法之一其實(shí)就是使用緩存。我們引入緩存,相當(dāng)于對(duì)數(shù)據(jù)進(jìn)行了復(fù)制。每當(dāng)系統(tǒng)數(shù)據(jù)更新時(shí),保持緩存和數(shù)據(jù)源(如 MySQL 數(shù)據(jù)庫)同步至關(guān)重要,當(dāng)然,這也取決于系統(tǒng)本身的要求,看系統(tǒng)是否允許一定的數(shù)據(jù)延遲。
最常見的幾種緩存策略、它們的優(yōu)缺點(diǎn)以及使用場(chǎng)景,分別是:
- Cache-Aside
- Read-Through
- Write-Through
- Write-Behind
Cache-Aside 策略
Cache-Aside可能是最常用的緩存策略。在這種策略下,應(yīng)用程序(Application)會(huì)與緩存(Cache)和數(shù)據(jù)源(Data Source)進(jìn)行通信,應(yīng)用程序會(huì)在命中數(shù)據(jù)源之前先檢查緩存。如下圖所示:

我們來看一次請(qǐng)求數(shù)據(jù)的過程:
- 首先,應(yīng)用程序先確定數(shù)據(jù)是否保留在緩存中;
- 如果數(shù)據(jù)在緩存中,也即 Cache hit ,稱作“緩存命中”。數(shù)據(jù)直接從緩存中讀取并返回給客戶端應(yīng)用程序;
- 如果數(shù)據(jù)不在緩存中,也即 Cache miss,稱作“緩存未命中”。應(yīng)用程序會(huì)從數(shù)據(jù)存儲(chǔ)的地方,如 MySQL 數(shù)據(jù)源中讀取該數(shù)據(jù),并將數(shù)據(jù)存儲(chǔ)在緩存中,然后將其返回給客戶端。
Cache-Aside策略特別適合“讀多”的應(yīng)用場(chǎng)景。使用Cache Aside策略的系統(tǒng)可以在一定程度上抵抗緩存故障。如果緩存服務(wù)發(fā)生故障,系統(tǒng)仍然可以通過直接訪問數(shù)據(jù)庫進(jìn)行操作。
然而,這種策略并不能保證數(shù)據(jù)存儲(chǔ)和緩存之間的一致性,需要配合使用其它策略來更新或使緩存無效。另外,首次請(qǐng)求數(shù)據(jù)時(shí),總是會(huì)導(dǎo)致緩存未命中,這種情況下需要額外的時(shí)間來將數(shù)據(jù)加載到緩存中。為了解決這個(gè)問題,開發(fā)人員可以通過手動(dòng)觸發(fā)查詢操作來對(duì)數(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)行大量讀取時(shí),Read-Through可以減少數(shù)據(jù)源上的負(fù)載,也對(duì)緩存服務(wù)的故障具備一定的彈性。如果緩存服務(wù)掛了,則緩存提供程序仍然可以通過直接轉(zhuǎn)到數(shù)據(jù)源來進(jìn)行操作。
然而,首次請(qǐng)求數(shù)據(jù)時(shí),總是會(huì)導(dǎo)致緩存未命中,并需要額外的時(shí)間來將數(shù)據(jù)加載到緩存中,相信大家都知道怎么處理了吧,還是“緩存預(yù)熱”的老套路。
Read-Through適用于多次請(qǐng)求相同數(shù)據(jù)的場(chǎng)景。這與Cache-Aside策略非常相似,但是二者還是存在一些差別,這里再次強(qiáng)調(diào)一下:
- 在Cache-Aside中,應(yīng)用程序負(fù)責(zé)從數(shù)據(jù)源中獲取數(shù)據(jù)并更新到緩存。
- 而在Read-Through中,此邏輯通常是由獨(dú)立的緩存提供程序支持。
以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
淺談一下Redis的數(shù)據(jù)結(jié)構(gòu)
這篇文章主要介紹了淺談一下Redis的數(shù)據(jù)結(jié)構(gòu),簡單字符串結(jié)構(gòu)被用于存儲(chǔ)redis的key對(duì)象和String類型的value對(duì)象,其中的free和len字段可以輕松的使得在該字符串被修改時(shí)判斷是否需要擴(kuò)容,需要的朋友可以參考下2023-08-08
Windows系統(tǒng)設(shè)置Redis服務(wù)使其開機(jī)自啟動(dòng)
Redis是一種鍵值對(duì)數(shù)據(jù)庫,也稱為內(nèi)存數(shù)據(jù)庫,因?yàn)樗梢詫?shù)據(jù)存儲(chǔ)在內(nèi)存中,而不是在磁盤上,下面這篇文章主要給大家介紹了關(guān)于Windows系統(tǒng)設(shè)置Redis服務(wù)使其開機(jī)自啟動(dòng)的相關(guān)資料,需要的朋友可以參考下2024-01-01
小白也能看懂的Redis遍歷鍵和數(shù)據(jù)庫管理詳解
這篇文章主要為大家介紹了小白也能看懂的Redis遍歷鍵和數(shù)據(jù)庫管理詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-10-10
redis啟動(dòng)報(bào)錯(cuò)Can‘t?open?the?log?file:?No?such?file?or?d
這篇文章主要介紹了redis啟動(dòng)報(bào)錯(cuò)Can‘t?open?the?log?file:?No?such?file?or?directory問題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-11-11
nestjs使用redis實(shí)現(xiàn)ip限流的步驟詳解
如果使用nestjs開發(fā)接口并部署之后,我們通常需要考慮到接口是否會(huì)被惡意盜刷消耗過多的資源,一個(gè)簡單的方式就是限制在單位時(shí)間內(nèi)的訪問次數(shù),所以本文給大家介紹了nestjs使用redis實(shí)現(xiàn)ip限流的步驟,需要的朋友可以參考下2025-01-01

