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

ASP.NET?Core?MVC緩存Tag?Helpers到內(nèi)存

 更新時間:2022年02月21日 16:42:45   作者:Sweet-Tang  
這篇文章介紹了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 ServerRedis。

另一個分布式緩存需要注意的是,它需要一個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 =&gt;
{
    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)存的文章就介紹到這了。希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

最新評論