擁抱.NET Core系列:MemoryCache 緩存域
在上一篇“《擁抱.NET Core系列:MemoryCache 緩存選項》”我們介紹了一些 MSCache 的機制,今天我們來介紹一下 MSCache 中的緩存域。
MSCache項目
MSCache 目前最新的正式版是 2.0.0,預覽版是2.1.0,會與 .NETCore 2.1 一起發布。本篇用了2.0.0版本
開源在 GitHub 上,倉庫地址是:https://github.com/aspnet/Caching
NuGet地址為:https://www.nuget.org/packages/Microsoft.Extensions.Caching.Memory/2.0.0
緩存域
我們來假設一個場景。
有下面四個成員
- 書籍模型(包含一個組章節模型)
- 章節模型
- 書籍服務
- 章節服務
BookService 有一個獲取書籍的方法
ChapterService 有一個獲取書籍章節的方法
可以看到 GetBook 內使用了緩存,緩存了5秒鐘。GetBook 又調用了 ChapterService 的 GetChapters,GetChapters 緩存了3秒鐘。
這時候書籍的章節信息緩存要早於書籍過期。
那麽大家試想一下,如果章節信息先過期了 GetBook 這個方法返回的是不是還是舊的數據?
在一些簡單的緩存設計中是這樣的,但在 MSCache 中微軟提供了緩存域的概念,從層級上 Chapter 的父級緩存是 Book。所以當 Chapter 過期時,Book 也會級聯過期。
我們來看一下測試。
可以看到,每隔三秒鐘不僅 Chapter 重新獲取,Book 也會一起級聯獲取。
這樣在很大程度上減輕了我們處理緩存依賴的問題。
ChaneToken在域中
SlidingExpiration在域中(畫重點)
恩,輸出是 時間,時間,新時間。
其實呢?
子緩存項並沒有過期。
這是為什麽呢?我翻了 Caching 的源碼發現,緩存失效擴散的處理中,並沒有對 SlidingExpiration 進行處理,只處理了 ExpirationTokens 和 AbsoluteExpiration。
不知道這是不是一個bug,我已經在 MSCache 項目上提了一個issue,等待回復後再來更新這塊的說明。
這塊的處理代碼如下:
邏輯很簡單,把自身的過期 token 和 絕對過期時間 設置在父緩存項上。
也就是說你在父緩存中設計的絕對到期時間會被改寫成到期緩存域中最小的到期時間。
寫在最後
MSCache 真的非常像 Orchard 中的 Caching,有興趣的同學可以去了解一些 Orchard 中的 Caching 設計。
至 此 MSCache 中的 MemoryCache 機制和功能就基本介紹完了。
後續會繼續介紹 MSCache 中的 DistributedCache(分布式緩存),和一些 MSCache 的使用技巧。
.NET技術棧QQ群:384413261(點擊加入 .NET Group)
擁抱.NET Core系列:MemoryCache 緩存域