经过减小生成内容所需的工做,缓存能够显著提升应用的性能和可伸缩性。 缓存对不常常更改的数据效果最佳。 缓存生成的数据副本的返回速度能够比从原始源返回更快。 应用程序应进行编写和测试到永远不会依赖于缓存的数据。html
ASP.NET Core 支持多种不一样的缓存。 最简单的缓存基于IMemoryCache,它表示存储在 Web 服务器内存中的缓存。 在服务器场的多个服务器运行的应用程序应确保使用内存中缓存时,都粘滞会话。 粘性会话可确保来自客户端的后续请求都转到同一台服务器。 例如,Azure Web 应用使用应用程序请求路由(ARR) 将全部的后续请求路由到同一台服务器。缓存
Web 场中的非粘性会话须要分布式缓存以免缓存一致性问题。 对于某些应用,分布式的缓存能够支持更高版本向外缩放比内存中缓存。 使用分布式缓存可将缓存内存卸载到外部进程。服务器
内存中缓存能够存储任何对象;分布式缓存接口仅限于byte[]
。 内存中和分布式缓存将缓存项存储为键 / 值对。分布式
IMemoryCache
以前须要添加引用,在程序包管理控制台中执行命令安装依赖包:1 PM> Install-Package Microsoft.Extensions.Caching.Memory -Version 2.2.0
备注:Microsoft.AspNetCore.App(2.2.0)元包含此包,若是已经安装过Microsoft.AspNetCore.App(2.2.0),则可跳过此步骤函数
在Startup类的ConfigureServices()方法中调用AddMemoryCache服务:性能
1 public void ConfigureServices(IServiceCollection services) 2 { 3 services.AddMemoryCache();
4 }
1 public class LoginController : Controller 2 { 3 private IMemoryCache _cache; 4 5 public LoginController(IMemoryCache memoryCache) 6 { 7 _cache = memoryCache; 8 }
如下代码使用cache缓存实现了 添加用户名验证缓存,在下次请求时会直接返回缓存内容,而不用从新查询,显著提升应用的性能。测试
1 //检查用户名是否存在 2 public JsonResult SelectUName(string uname) 3 { 4 //读取缓存 5 var cache = _cache.Get("re_" + uname); 6 if (cache == null)//若是没有该缓存 7 { 8 //查询用户名是否存在 9 var re = _userdal.SelectUName(uname); 10 //将验证结果添加到缓存 11 _cache.Set("re_" + uname, re.Status, new MemoryCacheEntryOptions().SetSlidingExpiration(TimeSpan.FromMinutes(10))); 12 return Json(new { status = re.Status }); 13 } 14 else//若是缓存不为空,则返回缓存内容 15 { 16 return Json(new { status = cache }); 17 } 18 }
"re_" + uname:缓存名
re.Status:缓存内容
new MemoryCacheEntryOptions().SetSlidingExpiration(TimeSpan.FromMinutes(10)):设置缓存过时时间
在删除或修改用户信息后,需清除缓存ui
1 //删除 2 public int Delete(int uid) 3 { 4 var re = _maindal.Delete(uid); 5 //删除成功以后移除验证用户名缓存 6 _cache.Remove("re_" + HttpContext.Session.GetString("name")); 7 return re; 8 }
备注:在缓存数据发生变化后,需清除缓存,下次请求时从新添加缓存this