虽然 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

使用 IDistributedCache

要想在 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

要想把 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();
        }

使用 NCache 进行CURD

为了方便演示,先来定义一个 Author 类,如下代码所示:


    public class Author
    {
        public int AuthorId { getset; }
        public string FirstName { getset; }
        public string LastName { getset; }
    }

接下来实现从 NCache 中读取 Author 对象,如果缓存中存在 Author 对象,则直接从缓存中读取,如果缓存中没有,则需要先从数据库中获取 Author,然后再将 Author 塞入到 Cache 中,下面的具体代码逻辑仅供参考。


        public async Task<Author> GetAuthor(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