.net core 的缓存方案

这里主要讲两个缓存的使用,MemoryCache和Redis

先讲讲常见的缓存

1、.net framework web中自带有Cache缓存,这种缓存属于粘性缓存,是缓存到项目中的,项目从服务器迁移的时候缓存的内容也能够随着服务器一起迁移

2、MemoryCache缓存则需要引用NuGet包 Microsoft.Extensions.Caching.Memory

3、Redis,Redis也有多种,我使用过ServiceStack.Redis和StackExchange.Reids,这两个的区别也是很大的ServiceStack.Redis是商用的,不给钱每个小时的使用是有限的,好像是六千次,但是速度稍微比StackExchange.Reids快一点点,毕竟是收费的,但是StackExchange.Reids没有使用限制,所以这里主要讲一下StackExchange.Reids怎么用

先讲MemoryCache怎么用吧

一、引用Microsoft.Extensions.Caching.Memory NuGet包

二、开写

private static IMemoryCache _memoryCache = null;

        public Cache()

        {

            _memoryCache = new MemoryCache(new MemoryCacheOptions());

        }

        /// <summary>

        /// 缓存绝对过期时间

        /// </summary>

        ///<param name="key">Cache键值</param>

        ///<param name="value">给Cache[key]赋的值</param>

        ///<param name="minute">minute分钟后绝对过期</param>

        public void CacheInsert(string key, object value, int minute)

        {

            if (value == null) return;

            _memoryCache.Set(key, value, new MemoryCacheEntryOptions()

                    .SetAbsoluteExpiration(TimeSpan.FromMinutes(minute)));

        }



        /// <summary>

        /// 缓存相对过期,最后一次访问后minute分钟后过期

        /// </summary>

        ///<param name="key">Cache键值</param>

        ///<param name="value">给Cache[key]赋的值</param>

        ///<param name="minute">滑动过期分钟</param>

        public void CacheInsertFromMinutes(string key, object value, int minute)

        {

            if (value == null) return;

            _memoryCache.Set(key, value, new MemoryCacheEntryOptions()

                    .SetSlidingExpiration(TimeSpan.FromMinutes(minute)));

        }

        /// <summary>

        ///写入缓存

        /// </summary>

        ///<param name="key">Cache键值</param>

        ///<param name="value">给Cache[key]赋的值</param>

        public void CacheInsert(string key, object value)

        {

            _memoryCache.Set(key, value);

        }

        /// <summary>

        ///清除指定缓存

        /// </summary>

        ///<param name="key"></param>

        public void RemoveCache(string key)

        {

            _memoryCache.Remove(key);

        }

        /// <summary>

        ///读取缓存

        /// </summary>

        ///<param name="key"></param>

        public object GetCache(string key)

        {

            return _memoryCache.Get(key);

        }

三、在要使用缓存的项目中的Startup类的ConfigureServices方法注入这个服务

services.AddSingleton(new CUE.Cache.Cache());

四、使用的页面就直接拿来用就好了

接收这个注入就可以用了,就像这样,完美

private readonly CUE.Cache.Cache _cache;

public HomeController(CUE.Cache.Cache cache)

{

    _cache = cache;

}

public IActionResult Index()

{

  _cache.CacheInsert("Key","vaule",10);

  return View();

}

一、现在用StackExchange.Redis

1,应为我们是把缓存封装到类库里面的,然而类库不能直接读取配置文件,redis又需要稍微配置已下连接地址,所以我有一篇文章讲怎么用类库读取配置文件的,有空可以去看一下

2.先引用StackExchange.Redis NuGet包

二、写配置文件

写到需要使用缓存的项目的appsettings.json里面

"Redis": {

    "Default": {

      "Connection": "127.0.0.1:6379",

      "InstanceName": "local",

      "DefaultDB": 8

    }

  }

三、读取配置文件

public class RedisConfigInfo

    {

        /// <summary>

        /// 读取Redis:Default 配置文件

        /// </summary>

        /// <returns></returns>

        public static IConfigurationSection GetConfig()

        {

            return ConfigHelper.GetSection("Redis:Default");

        }

        /// <summary>

        /// 读取Redis:Default下指定的值

        /// </summary>

        /// <param name="Key"></param>

        /// <returns></returns>

        public static string GetConfigValue(string Key)

        {

            return GetConfig().GetSection(Key).Value;

        }

    }

三、写连接字符串

public class RedisCathe

    {

        //连接字符串

        private string _connectionString;

        //实例名称

        private string _instanceName;

        //数据库

        private int _defaultDB;

        private ConcurrentDictionary<string, ConnectionMultiplexer> _connections;

        public RedisCathe()

        {

            _connectionString = RedisConfigInfo.GetConfigValue("Connection");

            _instanceName = RedisConfigInfo.GetConfigValue("InstanceName");

            //给定默认数据库,默认为0

            _defaultDB = int.Parse(RedisConfigInfo.GetConfigValue("DefaultDB") ?? "0");

            _connections = new ConcurrentDictionary<string, ConnectionMultiplexer>();

        }



        /// <summary>

        /// 获取ConnectionMultiplexer

        /// </summary>

        /// <returns></returns>

        private ConnectionMultiplexer GetConnect()

        {

            return _connections.GetOrAdd(_instanceName, p => ConnectionMultiplexer.Connect(_connectionString));

        }



        /// <summary>

        /// 获取数据库

        /// </summary>

        /// <param name="configName"></param>

        /// <param name="db">默认为0:优先代码的db配置,其次config中的配置</param>

        /// <returns></returns>

        public IDatabase GetDatabase()

        {

            return GetConnect().GetDatabase(_defaultDB);

        }



        public IServer GetServer(string configName = null, int endPointsIndex = 0)

        {

            var confOption = ConfigurationOptions.Parse(_connectionString);

            return GetConnect().GetServer(confOption.EndPoints[endPointsIndex]);

        }



        public ISubscriber GetSubscriber(string configName = null)

        {

            return GetConnect().GetSubscriber();

        }



        public void Dispose()

        {

            if (_connections != null && _connections.Count > 0)

            {

                foreach (var item in _connections.Values)

                {

                    item.Close();

                }

            }

        }

    }

三、封装方法

public class Cache

    {

        private readonly IDatabase _redis;

        public Cache()

        {

            _redis = new RedisCathe().GetDatabase();

        }

        /// <summary>

        ///写入缓存

        /// </summary>

        ///<param name="key">Cache键值</param>

        ///<param name="value">给Cache[key]赋的值</param>

        public void CacheInsert(string key, string value)

        {

            _redis.StringSet(key, value);

        }



        /// <summary>

        /// 缓存过期时间

        /// </summary>

        ///<param name="key">Cache键值</param>

        ///<param name="value">给Cache[key]赋的值</param>

        ///<param name="minute">minute分钟后绝对过期</param>

        public void CacheInsert(string key, string value, int minute)

        {

            _redis.StringSet(key, value, TimeSpan.FromMinutes(minute));

        }

        /// <summary>

        ///读取缓存

        /// </summary>

        ///<param name="key"></param>

        public string GetCache(string key)

        {

            return _redis.StringGet(key);

        }



        /// <summary>

        ///清除指定缓存

        /// </summary>

        ///<param name="key"></param>

        public void RemoveCache(string key)

        {

            _redis.KeyDelete(key);

        }

    }

四、用法就和上面的Cache一模一样,先注入,然后直接用就行了

相关推荐
小兜全糖(xdqt)1 小时前
.netCore WebAPI中字符串加密与解密
.netcore
沪上百卉1 小时前
.NET Core 常用的三个生命周期
.netcore
成富3 小时前
文本转SQL(Text-to-SQL),场景介绍与 Spring AI 实现
数据库·人工智能·sql·spring·oracle
鹿屿二向箔4 小时前
基于SSM(Spring + Spring MVC + MyBatis)框架的汽车租赁共享平台系统
spring·mvc·mybatis
材料苦逼不会梦到计算机白富美4 小时前
golang分布式缓存项目 Day 1
分布式·缓存·golang
豪宇刘4 小时前
SpringBoot+Shiro权限管理
java·spring boot·spring
Java 第一深情4 小时前
高性能分布式缓存Redis-数据管理与性能提升之道
redis·分布式·缓存
HBryce245 小时前
缓存-基础概念
java·缓存
一只爱打拳的程序猿5 小时前
【Spring】更加简单的将对象存入Spring中并使用
java·后端·spring
ajsbxi8 小时前
苍穹外卖学习记录
java·笔记·后端·学习·nginx·spring·servlet