ASP.NET?Core?MVC緩存Tag?Helpers到內(nèi)存
簡介
緩存可以大大提高應(yīng)用程序加載時間和響應(yīng)速度。我們可以使用緩存Tag Helpers緩存不會頻繁更改的HTML內(nèi)容。
在上一篇文章中,我們談到了Tag Helpers,演示Tag Helpers能做什么、如何使用它們以及一些最常用的Tag Helpers。
今天,我們將看看如何使用緩存Tag Helpers和它們的益處。
Cache Tag Helper
首先說一下 <cache> Tag Helper。與其它Tag Helper不同,其它Tag Helper被當(dāng)作屬性使用,緩存Tag Helper作為標(biāo)簽使用 - <cache>。它根據(jù)其屬性指定的選項,將包含的內(nèi)容緩存到內(nèi)存中。
讓我們看一個示例代碼:

當(dāng)我們第一次打開頁面,會看到當(dāng)前的時間;但是,如果我們在30秒內(nèi)刷新頁面,我們每次都會得到相同的內(nèi)容。然而,一旦每30秒過去之后,就會有新的內(nèi)容,我們將在輸出中再次看到當(dāng)前時間。
我們通過三個與時間相關(guān)屬性選項來控制緩存Tag Helper:

- expires-after - 最常用的一個,它表示緩存內(nèi)容過期的時間段(timespan)
- expires-on - 過期的時間點
- expires-sliding – 每次內(nèi)容被請求后緩存被延長的時間(timespan)
vary-by 屬性
Cache Tag Helpers通過上下文是生成唯一的ID來創(chuàng)建緩存鍵,這意味著我們可以在同一個視圖內(nèi)部有多個Cache Tag Helpers,這些內(nèi)容將是唯一的,不會重疊。我們還可以通過使用vary-by屬性或任何vary-by屬性的組合來指定Cache Tag Helpers使用更復(fù)雜的鍵。
vary by 屬性后綴列表:
- query
- route
- cookie
- header
- user
vary-by-query
它基于當(dāng)前請求的查詢參數(shù)創(chuàng)建唯一的緩存鍵。
看下面的代碼:

我們在頁面上看到下面的輸出和變化:

vary-by-route
基于某一個路由參數(shù)來創(chuàng)建唯一的緩存,逗號分隔路由參數(shù)名稱列表。
vary-by-cookie
根據(jù)存儲在cookie中的某一個值來創(chuàng)建唯一的緩存,逗號分隔cookie名稱列表。
vary-by-header
基于請求頭的某一個參數(shù)來創(chuàng)建唯一的緩存,只需要單個請求頭名稱。
vary-by-user
根據(jù)當(dāng)前登錄用戶創(chuàng)建唯一的緩存,屬性的值為布爾值類型。
我們還可以做哪一些?
正如我們看到的,<cache>Tag Helper非常酷,它將緩存數(shù)據(jù)存儲在本地進(jìn)程的內(nèi)存中,如果服務(wù)器進(jìn)程重新啟動,所有緩存內(nèi)容都將丟失。
此外,如果我們有多臺服務(wù)器,每臺服務(wù)器都有自己的緩存,這估計不是您期望的。
您可以使用所謂的粘滯會話(sticky sessions),粘滯會話(sticky sessions)確保同一客戶端的所有請求都轉(zhuǎn)到同一臺服務(wù)器。
處理多臺服務(wù)器緩存不一致的另一種方法是使用分布式緩存。這就是為什么ASP.NET團隊也做了<distributed-cache> Tag Helper。讓我們看看這是什么東東。
分布式 Cache Tag Helper
為什么我們應(yīng)該使用分布式緩存?
- 支持更高的縮放比例(與內(nèi)存緩存相比)
- 使用分布式緩存將緩存內(nèi)存遷移到外部進(jìn)程
- 我們在所有的Web服務(wù)器上得到一致的數(shù)據(jù)(用戶總是得到相同的結(jié)果,無論他們訪問到哪臺Web服務(wù)器)
- 緩存的數(shù)據(jù)在服務(wù)器重新啟動和部署時不會丟失
- 我們可以停止或添加Web服務(wù)器,不會丟失緩存的數(shù)據(jù)
現(xiàn)在我們談?wù)勎覀兦懊嫣岬降姆植际骄彺鎀ag Helper。
分布式緩存Tag Helper的行為與緩存Tag helper幾乎相同。對<cache> Tag Helper提供每一個屬性也可用于<distributed-cache> Tag Helper。
但是,Distributed Cache TagHelper的區(qū)別在于它使我們能夠注入和使用外部緩存管理器,而不是使用默認(rèn)的內(nèi)存緩存管理器。
如果您需要將緩存的HTML內(nèi)容存儲在用SQL Server、Redis等分布式緩存中,那么您需要<distributed-cache> Tag Helper。
ASP.NET Core MVC提供兩個緩存管理器的實現(xiàn),分別是SQL Server和Redis。
另一個分布式緩存需要注意的是,它需要一個name屬性。

那么我們?nèi)绾问褂肨ag Helper實現(xiàn)分布式緩存?很簡單,但是如果我們只是將<distributed-cache> Tag Helper直接放在Razor代碼中是不起作用的。
在ASP.NET Core MVC 1.1中的使用示例
讓我們將Redis添加為我們的分布式緩存管理器:
- 安裝并啟動Redis
- 添加NuGet軟件包:
Microsoft.Extensions.Caching.Redis - 在ConfigureServices方法中添加以下代碼:
services.AddDistributedRedisCache(option =>
{
option.Configuration = "localhost";
option.InstanceName = "localRedis";
});
就這么簡單!現(xiàn)在,<distributed-cache> Tag Helpers將緩存的內(nèi)容存儲到Redis中。
在ASP.NET Core 2中更容易,因為Microsoft.Extensions.Caching.Redis已經(jīng)在Microsoft.AspNetCore.All包中了。
總結(jié)
- Caching Tag Helpers對于緩存HTML內(nèi)容非常有用
- <cache> Tag Helper將緩存內(nèi)容存儲在內(nèi)存中,一旦我們的務(wù)器的進(jìn)程重啟,就會丟失所有緩存的內(nèi)容
- <distributed-cache>與 <cache> TagHelper 幾乎相同,只需要增加name屬性,就可以將內(nèi)存緩存遷移到分布式緩存管理器
- 控制緩存過期時間三個最重要的屬性:
- expires-after – 最常用的一個,它表示緩存內(nèi)容過期的時間段(timespan)
- expires-on – 過期的時間點
- expires-sliding – 每次內(nèi)容被請求后緩存被延長的時間(timespan)
到此這篇關(guān)于ASP.NET Core MVC緩存Tag Helpers到內(nèi)存的文章就介紹到這了。希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
.NET從優(yōu)酷專輯中采集所有視頻及信息(VB.NET代碼)
因為想做一個視頻點播類的網(wǎng)站,所以開始研究視頻采集。2010-02-02
淺談對Jquery+JSON+WebService的使用小結(jié)
本篇文章介紹了對Jquery+JSON+WebService的使用小結(jié)。需要的朋友參考下2013-04-04
asp.net core 集成swagger ui的原理解析
本文主要講解了如何對API進(jìn)行分組,這里僅僅是舉了一個按照API功能進(jìn)行分組的例子,其實在實際開發(fā)中,要按照何種方式分組,可以按照需求靈活定義,比如按照API版本進(jìn)行分組2021-10-10
ASP.NET MVC5+EF6+EasyUI后臺管理系統(tǒng) 微信公眾平臺開發(fā)之資源環(huán)境準(zhǔn)備
這篇文章主要介紹了ASP.NET MVC5+EF6+EasyUI后臺管理系統(tǒng),微信公眾平臺開發(fā)之資源環(huán)境準(zhǔn)備,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-09-09

