ASP.NET?Core?MVC緩存Tag?Helpers到內(nèi)存
簡介
緩存可以大大提高應用程序加載時間和響應速度。我們可以使用緩存Tag Helpers緩存不會頻繁更改的HTML內(nèi)容。
在上一篇文章中,我們談到了Tag Helpers,演示Tag Helpers能做什么、如何使用它們以及一些最常用的Tag Helpers。
今天,我們將看看如何使用緩存Tag Helpers和它們的益處。
Cache Tag Helper
首先說一下 <cache> Tag Helper。與其它Tag Helper不同,其它Tag Helper被當作屬性使用,緩存Tag Helper作為標簽使用 - <cache>。它根據(jù)其屬性指定的選項,將包含的內(nèi)容緩存到內(nèi)存中。
讓我們看一個示例代碼:
當我們第一次打開頁面,會看到當前的時間;但是,如果我們在30秒內(nèi)刷新頁面,我們每次都會得到相同的內(nèi)容。然而,一旦每30秒過去之后,就會有新的內(nèi)容,我們將在輸出中再次看到當前時間。
我們通過三個與時間相關屬性選項來控制緩存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使用更復雜的鍵。
vary by
屬性后綴列表:
- query
- route
- cookie
- header
- user
vary-by-query
它基于當前請求的查詢參數(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ù)當前登錄用戶創(chuàng)建唯一的緩存,屬性的值為布爾值類型。
我們還可以做哪一些?
正如我們看到的,<cache>Tag Helper非???,它將緩存數(shù)據(jù)存儲在本地進程的內(nèi)存中,如果服務器進程重新啟動,所有緩存內(nèi)容都將丟失。
此外,如果我們有多臺服務器,每臺服務器都有自己的緩存,這估計不是您期望的。
您可以使用所謂的粘滯會話(sticky sessions),粘滯會話(sticky sessions)確保同一客戶端的所有請求都轉到同一臺服務器。
處理多臺服務器緩存不一致的另一種方法是使用分布式緩存。這就是為什么ASP.NET團隊也做了<distributed-cache> Tag Helper。讓我們看看這是什么東東。
分布式 Cache Tag Helper
為什么我們應該使用分布式緩存?
- 支持更高的縮放比例(與內(nèi)存緩存相比)
- 使用分布式緩存將緩存內(nèi)存遷移到外部進程
- 我們在所有的Web服務器上得到一致的數(shù)據(jù)(用戶總是得到相同的結果,無論他們訪問到哪臺Web服務器)
- 緩存的數(shù)據(jù)在服務器重新啟動和部署時不會丟失
- 我們可以停止或添加Web服務器,不會丟失緩存的數(shù)據(jù)
現(xiàn)在我們談談我們前面提到的分布式緩存Tag Helper。
分布式緩存Tag Helper的行為與緩存Tag helper幾乎相同。對<cache> Tag Helper提供每一個屬性也可用于<distributed-cache> Tag Helper。
但是,Distributed Cache TagHelper的區(qū)別在于它使我們能夠注入和使用外部緩存管理器,而不是使用默認的內(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
包中了。
總結
- Caching Tag Helpers對于緩存HTML內(nèi)容非常有用
- <cache> Tag Helper將緩存內(nèi)容存儲在內(nèi)存中,一旦我們的務器的進程重啟,就會丟失所有緩存的內(nèi)容
- <distributed-cache>與 <cache> TagHelper 幾乎相同,只需要增加name屬性,就可以將內(nèi)存緩存遷移到分布式緩存管理器
- 控制緩存過期時間三個最重要的屬性:
- expires-after – 最常用的一個,它表示緩存內(nèi)容過期的時間段(timespan)
- expires-on – 過期的時間點
- expires-sliding – 每次內(nèi)容被請求后緩存被延長的時間(timespan)
到此這篇關于ASP.NET Core MVC緩存Tag Helpers到內(nèi)存的文章就介紹到這了。希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
.NET從優(yōu)酷專輯中采集所有視頻及信息(VB.NET代碼)
因為想做一個視頻點播類的網(wǎng)站,所以開始研究視頻采集。2010-02-02淺談對Jquery+JSON+WebService的使用小結
本篇文章介紹了對Jquery+JSON+WebService的使用小結。需要的朋友參考下2013-04-04asp.net core 集成swagger ui的原理解析
本文主要講解了如何對API進行分組,這里僅僅是舉了一個按照API功能進行分組的例子,其實在實際開發(fā)中,要按照何種方式分組,可以按照需求靈活定義,比如按照API版本進行分組2021-10-10ASP.NET MVC5+EF6+EasyUI后臺管理系統(tǒng) 微信公眾平臺開發(fā)之資源環(huán)境準備
這篇文章主要介紹了ASP.NET MVC5+EF6+EasyUI后臺管理系統(tǒng),微信公眾平臺開發(fā)之資源環(huán)境準備,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-09-09