網站首頁 編程語言 正文
簡介
緩存可以大大提高應用程序加載時間和響應速度。我們可以使用緩存Tag Helpers緩存不會頻繁更改的HTML內容。
在上一篇文章中,我們談到了Tag Helpers,演示Tag Helpers能做什么、如何使用它們以及一些最常用的Tag Helpers。
今天,我們將看看如何使用緩存Tag Helpers和它們的益處。
Cache Tag Helper
首先說一下?
讓我們看一個示例代碼:
當我們第一次打開頁面,會看到當前的時間;但是,如果我們在30秒內刷新頁面,我們每次都會得到相同的內容。然而,一旦每30秒過去之后,就會有新的內容,我們將在輸出中再次看到當前時間。
我們通過三個與時間相關屬性選項來控制緩存Tag Helper:
- expires-after - 最常用的一個,它表示緩存內容過期的時間段(timespan)
- expires-on - 過期的時間點
- expires-sliding – 每次內容被請求后緩存被延長的時間(timespan)
vary-by?屬性
Cache Tag Helpers通過上下文是生成唯一的ID來創建緩存鍵,這意味著我們可以在同一個視圖內部有多個Cache Tag Helpers,這些內容將是唯一的,不會重疊。我們還可以通過使用vary-by
屬性或任何vary-by
屬性的組合來指定Cache Tag Helpers使用更復雜的鍵。
vary by
?屬性后綴列表:
- query
- route
- cookie
- header
- user
vary-by-query
它基于當前請求的查詢參數創建唯一的緩存鍵。
看下面的代碼:
我們在頁面上看到下面的輸出和變化:
vary-by-route
基于某一個路由參數來創建唯一的緩存,逗號分隔路由參數名稱列表。
vary-by-cookie
根據存儲在cookie中的某一個值來創建唯一的緩存,逗號分隔cookie名稱列表。
vary-by-header
基于請求頭的某一個參數來創建唯一的緩存,只需要單個請求頭名稱。
vary-by-user
根據當前登錄用戶創建唯一的緩存,屬性的值為布爾值類型。
我們還可以做哪一些?
正如我們看到的,
此外,如果我們有多臺服務器,每臺服務器都有自己的緩存,這估計不是您期望的。
您可以使用所謂的粘滯會話(sticky sessions),粘滯會話(sticky sessions)確保同一客戶端的所有請求都轉到同一臺服務器。
處理多臺服務器緩存不一致的另一種方法是使用分布式緩存。這就是為什么ASP.NET團隊也做了
分布式 Cache Tag Helper
為什么我們應該使用分布式緩存?
- 支持更高的縮放比例(與內存緩存相比)
- 使用分布式緩存將緩存內存遷移到外部進程
- 我們在所有的Web服務器上得到一致的數據(用戶總是得到相同的結果,無論他們訪問到哪臺Web服務器)
- 緩存的數據在服務器重新啟動和部署時不會丟失
- 我們可以停止或添加Web服務器,不會丟失緩存的數據
現在我們談談我們前面提到的分布式緩存Tag Helper。
分布式緩存Tag Helper的行為與緩存Tag helper幾乎相同。對
但是,Distributed Cache TagHelper的區別在于它使我們能夠注入和使用外部緩存管理器,而不是使用默認的內存緩存管理器。
如果您需要將緩存的HTML內容存儲在用SQL Server、Redis等分布式緩存中,那么您需要
ASP.NET Core MVC提供兩個緩存管理器的實現,分別是SQL Server和Redis。
另一個分布式緩存需要注意的是,它需要一個name屬性。
那么我們如何使用Tag Helper實現分布式緩存?很簡單,但是如果我們只是將
在ASP.NET Core MVC 1.1中的使用示例
讓我們將Redis添加為我們的分布式緩存管理器:
- 安裝并啟動Redis
- 添加NuGet軟件包:?
Microsoft.Extensions.Caching.Redis
- 在ConfigureServices方法中添加以下代碼:
services.AddDistributedRedisCache(option => { option.Configuration = "localhost"; option.InstanceName = "localRedis"; });
就這么簡單!現在,
在ASP.NET Core 2中更容易,因為Microsoft.Extensions.Caching.Redis
已經在Microsoft.AspNetCore.All
包中了。
總結
- Caching Tag Helpers對于緩存HTML內容非常有用
-
?Tag Helper將緩存內容存儲在內存中,一旦我們的務器的進程重啟,就會丟失所有緩存的內容 -
與? ?TagHelper 幾乎相同,只需要增加name屬性,就可以將內存緩存遷移到分布式緩存管理器 - 控制緩存過期時間三個最重要的屬性:
- expires-after – 最常用的一個,它表示緩存內容過期的時間段(timespan)
- expires-on – 過期的時間點
- expires-sliding – 每次內容被請求后緩存被延長的時間(timespan)
原文鏈接:https://www.cnblogs.com/tdfblog/p/caching-taghelpers-in-asp-net-core-mvc.html
相關推薦
- 2022-03-14 springboot下Static變量通過@Value和set方法注入失敗的問題和解決辦法
- 2022-10-13 Python?YAML文件的讀寫操作詳解_python
- 2022-12-21 Android?RecyclerView四級緩存源碼層詳細分析_Android
- 2022-10-10 Android開發之permission動態權限獲取詳解_Android
- 2023-02-17 Python排序算法之冒泡排序_python
- 2022-05-27 五個經典鏈表OJ題帶你進階C++鏈表篇_C 語言
- 2022-03-29 jQuery實現小球點擊發射動畫_jquery
- 2022-07-22 C語言實現在屏幕上打印特定的*星號圖案
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支