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

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

 更新時間:2020年08月04日 10:34:06   作者:Tracydzf  
這篇文章主要介紹了Redis緩存常用4種策略原理詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下

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

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

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

Cache-Aside 策略

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

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

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

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

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

Read-Through 策略

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

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

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

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

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

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

相關文章

  • Redis實現(xiàn)延遲任務的常見方案詳解

    Redis實現(xiàn)延遲任務的常見方案詳解

    延遲任務(Delayed?Task)是指在未來的某個時間點,執(zhí)行相應的任務,本文為大家整理了Redis實現(xiàn)延遲任務的幾個常見方案,希望對大家有所幫助
    2024-04-04
  • 攔截Redis命令導致的Lua腳本執(zhí)行失敗的問題解決

    攔截Redis命令導致的Lua腳本執(zhí)行失敗的問題解決

    本文主要介紹了攔截Redis命令導致的Lua腳本執(zhí)行失敗的問題解決,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-06-06
  • Windows操作系統(tǒng)下Redis服務安裝圖文教程

    Windows操作系統(tǒng)下Redis服務安裝圖文教程

    這篇文章主要介紹了Windows操作系統(tǒng)下Redis服務安裝圖文教程,文中給大家提供了redis的下載地址,安裝程序步驟,需要的朋友可以參考下
    2018-03-03
  • Redis設置鍵的生存時間或過期時間的方法詳解

    Redis設置鍵的生存時間或過期時間的方法詳解

    這篇文章主要介紹了Redis如何設置鍵的生存時間或過期時間,通過EXPIRE命令或者PEXIPIRE命令,客戶端可以以秒或者毫秒精度為數(shù)據(jù)庫中的某個鍵設置生存時間,文中有詳細的代碼供供大家參考,需要的朋友可以參考下
    2024-03-03
  • Redis和數(shù)據(jù)庫 數(shù)據(jù)同步問題的解決

    Redis和數(shù)據(jù)庫 數(shù)據(jù)同步問題的解決

    這篇文章主要介紹了Redis和數(shù)據(jù)庫 數(shù)據(jù)同步問題的解決操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-01-01
  • redis通過pipeline提升吞吐量的方法

    redis通過pipeline提升吞吐量的方法

    下面小編就為大家分享一篇redis通過pipeline提升吞吐量的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-02-02
  • Redis主從復制與讀寫分離的實現(xiàn)

    Redis主從復制與讀寫分離的實現(xiàn)

    Redis在作為緩存的時候,隨著項目訪問量的增加,對Redis服務器的操作也越加頻繁,雖然Redis讀寫速度都很快,但是一定程度上也會造成一定的延時,本文主要介紹了Redis主從復制與讀寫分離的實現(xiàn),具有一定的參考價值,感興趣的可以了解一下
    2023-12-12
  • 5分鐘搭建redis集群(redis5.0.5)

    5分鐘搭建redis集群(redis5.0.5)

    本文主要介紹了5分鐘搭建redis集群,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-08-08
  • redis哨兵模式分布式鎖實現(xiàn)與實踐方式(redisson)

    redis哨兵模式分布式鎖實現(xiàn)與實踐方式(redisson)

    這篇文章主要介紹了redis哨兵模式分布式鎖實現(xiàn)與實踐方式(redisson),具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • 保證Redis中存儲的Token安全性的示例詳解

    保證Redis中存儲的Token安全性的示例詳解

    確保Redis中存儲的Token安全性是一個多層面的任務,涉及到網(wǎng)絡、應用、數(shù)據(jù)和操作等多個方面的安全措施,本文給大家介紹了一些詳細的實踐建議和示例,并有詳細的代碼供大家參考,需要的朋友可以參考下
    2024-03-03

最新評論