本文共 2766 字,大约阅读时间需要 9 分钟。
虽然 ASP.Net Core 中缺少 Cache 对象,但它引入了三种不同的cache方式。
内存缓存
分布式缓存
Response缓存
Alachisoft 公司提供了一个开源项目 NCache,它是一个高性能的,分布式的,可扩展的缓存框架,NCache不仅比 Redis 快,而且还提供了一些Redis所不具有的分布式特性,如果你想了解 NCache 和 Redis 的异同,可参考如下链接:http://www.alachisoft.com/resources/comparisons/redis-vs-ncache.php ,这篇文章我们将会讨论如何在 ASP.Net Core 中使用 NCache。
要想在 ASP.Net Core 中使用 NCache,需要通过 NuGet 安装如下包,你可以通过 NuGet Package Manager console 窗口输入如下命令进行安装。
Install-Package Alachisoft.NCache.SessionServices
要想在 ASP.Net Core 中使用分布式缓存,需要实现 IDistributedCache 接口,这个接口主要用于让第三方的缓存框架无缝对接到 ASP.Net Core 中,下面是 IDistributedCache 的骨架代码。
namespace Microsoft.Extensions.Caching.Distributed { public interface IDistributedCache { byte[] Get(string key); void Refresh(string key); void Remove(string key); void Set(string key, byte[] value, DistributedCacheEntryOptions options); } }
要想把 NCache 作为分布式缓存,需要在 ConfigureServices()
中调用 AddNCacheDistributedCache 扩展方法将其注入到容器中,如下代码所示:
// This method gets called by the runtime. Use this method to add services to the container. public void ConfigureServices(IServiceCollection services) { services.AddNCacheDistributedCache(configuration => { configuration.CacheName = "IDGDistributedCache"; configuration.EnableLogs = true; configuration.ExceptionsEnabled = true; }); services.AddControllersWithViews(); }
为了方便演示,先来定义一个 Author 类,如下代码所示:
public class Author { public int AuthorId { get; set; } public string FirstName { get; set; } public string LastName { get; set; } }
接下来实现从 NCache 中读取 Author 对象,如果缓存中存在 Author 对象,则直接从缓存中读取,如果缓存中没有,则需要先从数据库中获取 Author,然后再将 Author 塞入到 Cache 中,下面的具体代码逻辑仅供参考。
public async TaskGetAuthor(int id) { _cache = NCache.InitializeCache("CacheName"); var cacheKey = "Key"; Author author = null; if (_cache != null) { author = _cache.Get(cacheKey) as Author; } if (author == null) //Data not available in the cache { if (_cache != null) { _cache.Insert(cacheKey, author, null, Cache.NoAbsoluteExpiration, TimeSpan.FromMinutes(10), Alachisoft.NCache.Runtime.CacheItemPriority.Default); } } return author; }
NCache 由 Alachisoft 出品给 .NET 世界提供了一种分布式缓存的解决方案,同时你也能看到 IDistributedCache 是一套标准的用于分布式缓存的高层API,方便第三方的缓存无缝接入,比如:Redis,Mongodb,Mysql 等等。
译文链接:https://www.infoworld.com/article/3342120/how-to-use-ncache-in-aspnet-core.html
转载地址:http://boudi.baihongyu.com/