AspnetCore 缓存篇

一、缓存的作用

怎样理解缓存:

其实所有的程序,架构,优化,线程...等技术手段,最终的目的都是如何使产品快速的响应用户的操作,提高用户的体验性,目标都是为了系统的使用者,缓存的存在也是同样的道理,缓存常用于存放不经常更改的数据信息,比如,用户的基础数据、Token等一些长被使用并且不常更改的.

举例说明

咱们就拿用户的登录操作来说,有一个系统是这样设计的,(1)用户(输入用户名:密码)登录》》》(2)首先程序做的是在缓存中查询数据,判断是否有缓存存在,缓存是否过期,如果缓存过期了》》》(3)进库查询用户是否具有登录的权限》》》最后是功能页面。  一张简单的图加深一下印象

在上图中我们可以看到如果缓存存在的话,我们大可不必进库去查询数据了,省去了查询的动作、开关库、判断的操作。加入这些动作可以省去1秒钟的时间,这就已经在提高用户的体验性了。

缓存的作用不只是这一个方面,建议大家多去找找资料,每个人学出来的东西都不一样。

比如缓存的状态、生存期、缓存的类别 等

二、ASPNet Core的内置缓存

AspNetCore支持多种缓存,首先说一下AspNetCore 的内置缓存 IMemoryCache

IMemoryCache把数据存储在Web服务器的内置缓存中,也就是Web服务器缓存,和 System.Web.HttpRuntime 缓存作用上差别不大 ,但是在Core中去掉了System.Web.HttpRuntime 的命名引用被移除,引入命名空间Microsoft.Extensions.Caching.Memory

使用NuGet管理工具添加如下:

针对Core缓存我们做出如下几个操作:

1.首先创建一个缓存:

操作步骤引入命名空间,Microsoft.Extensions.Caching.Memory

在我们的帮助类中用构造器注入的方式创建IMemoryCache 的对象

代码如下

private IMemoryCache _cache;
//构造器注入
public CoreMemoryCache(IMemoryCache memoryCache)
{
_cache = memoryCache;
}

创建缓存的方法有两个:

(1) Set(); 创建一个缓存项,可以设置缓存项的绝对和滑动过期时间,优先级等。

(2) GetOrCreate(); 方法的含义和命名一致,获取或创建,如果缓存存在则获取缓存项,如果不存在则创建缓存项。

代码如下

(1)Set();

public bool Add(string key, object value)
{
if (string.IsNullOrEmpty(key))
{
#region ArgumentNullException说明
/*
* 如果不想返回异常信息的话也可以返回 自己定义的
* 当参数为空时放生的异常
* 和 ArgumentException 作用相同
*/
#endregion
// throw new ArgumentNullException(key);
}
else
{
MemoryCacheEntryOptions cacheExpirationOptions = new MemoryCacheEntryOptions();
cacheExpirationOptions.AbsoluteExpiration = DateTime.Now.AddMinutes();
cacheExpirationOptions.Priority = CacheItemPriority.Normal;
cacheExpirationOptions.RegisterPostEvictionCallback(IDGCacheItemChangedHandler, this);
//添加
//类似 System.Web.HttpRuntime.Cache[key]
_cache.Set(key, value, cacheExpirationOptions);
}
//如果添加成功则验证是否存在返回True 或false
return Exists(key);
}
设置缓存的CacheItemPriority

添加缓存的时候利用MemoryCacheEntryOptions 来设置缓存:重点

具体实现:

利用缓存中Set方法最后一个参数  上方截图

MemoryCacheEntryOptions:绝对重要,他决定着怎么设置绝对过期时间和滑动过期时间,优先级等

缓存添加实现如下
MemoryCacheEntryOptions cacheExpirationOptions = new MemoryCacheEntryOptions();
//绝对过期时间
cacheExpirationOptions.AbsoluteExpiration = DateTime.Now.AddMinutes();
//缓存优先级
cacheExpirationOptions.Priority = CacheItemPriority.Normal;
//添加缓存
_cache.Set(key, value, cacheExpirationOptions);

MemoryCacheEntryOptions的Priority属性。 Priority属性指定应将哪些对象(基于已设置的优先级)从缓存中删除,作为每当Web服务器内存空间不足时回收内存的运行时策略的一部分。要设置优先级,我们使用CacheItemPriority枚举。这可以具有以下可能的值之一:低,正常,高和NeverRemove。 ASP.Net Core中的内存缓存提供程序将在内存压力下移除缓存条目,如果将缓存优先级设置为CacheItemPriority.NeverRemove。这个时候我们可以注册一个回调,该回调将在从缓存中移除条目时执行

MemoryCacheEntryOptions中的 RegisterPostEvictionCallback 这个可以用来记录日志什么的

举例代码如下:

cacheExpirationOptions.RegisterPostEvictionCallback(AddCallback,this);

 //public enum EvictionReason
//{
// None = 0,
// //
// // 摘要:
// // Manually
// Removed = 1,
// //
// // 摘要:
// // Overwritten
// Replaced = 2,
// //
// // 摘要:
// // Timed out
// Expired = 3,
// //
// // 摘要:
// // Event
// TokenExpired = 4,
// //
// // 摘要:
// // Overflow
// Capacity = 5
//} public void AddCallback(object key, object value, EvictionReason reason, object state)
{
_cache.Set("CallbackMsg", reason);
}

(2)GetOrCreate();

代码如下:

代码如下:
/// <summary>
/// 存在创建不存在获取
/// </summary>
/// <param name="key"></param>
/// <param name="value"></param>
/// <returns></returns>
public bool AddOrCreate(string key, object value)
{
if (string.IsNullOrEmpty(key))
{ }
else
{
// public static TItem GetOrCreate<TItem>(this IMemoryCache cache, object key, Func<ICacheEntry, TItem> factory);
_cache.GetOrCreate(key, ENTRY => { return value; });
}
//如果添加成功则验证是否存在
return Exists(key);
}

2. 删除缓存

(1) Remove();

这个见名就知道了

代码如下:

/// <summary>
/// 删除缓存
/// </summary>
/// <param name="key"></param>
/// <returns></returns>
public bool Remove(string key)
{
if (string.IsNullOrEmpty(key))
{
return false;
}
else
{
//删除
_cache.Remove(key); //如果删除成功则验证是否存在返回bool
return !Exists(key);
}
}

3. 修改缓存

(1)修改缓存并没有具体的方法,咱们代码走的是,先删除后添加的方法

代码如下:

/// <summary>
/// 修改缓存
/// </summary>
/// <param name="key"></param>
/// <param name="value"></param>
/// <returns></returns>
/// 修改时 MemoryCache 没有提供相对相应的方法,先删除后添加
public bool Modify(string key, object value)
{
bool ReturnBool = false;
if (string.IsNullOrEmpty(key))
{ }
else
{
if (Exists(key))
{
//删除
if (!Remove(key))
{
ReturnBool = Add(key, value);
}
} }
return ReturnBool;

4.获取缓存项

(1)Get();

代码如下:

 /// <summary>
/// 获取缓存
/// </summary>
/// <param name="key"></param>
/// <returns></returns>
public object Get(string key)
{
if (string.IsNullOrEmpty(key))
{
return false;
}
else
{ #region 另一种判断方式
/*
_cache.TryGetValue(key, out ReturnValue)检索缓存输出Bool;
用这个也可以直接把 out 输出就行
*/
#endregion
return _cache.Get(key); }
}

5.验证缓存是否存在

代码如下:利用TryGetValue();

/// <summary>
/// 验证缓存是否存在
/// </summary>
/// <param name="key"></param>
/// <returns></returns>
public bool Exists(string key)
{
object ReturnValue;
if (string.IsNullOrEmpty(key))
{
return false;
}
else
{
return _cache.TryGetValue(key, out ReturnValue);
}
}

缓存中整体的方法,不过有的没去实现

下面是所有方法的截图:

睡觉了一点半了,后面写的有点捉急抱歉,

 欢迎大家指出错误之处,转载注明出处,谢谢

AspnetCore 缓存篇的更多相关文章

  1. jQuery2.x源码解析(缓存篇)

    jQuery2.x源码解析(构建篇) jQuery2.x源码解析(设计篇) jQuery2.x源码解析(回调篇) jQuery2.x源码解析(缓存篇) 缓存是jQuery中的又一核心设计,jQuery ...

  2. 缓存篇(Cache)~大话开篇

    回到占占推荐博客索引 闲话杂淡 想写这篇文章很久了,但总是感觉内功还不太够,总觉得,要写这种编程领域里的心法(内功)的文章,需要有足够的实践,需要对具体领域非常了解,才能写出来.如今,感觉自己有写这种 ...

  3. 缓存篇(Cache)~第一回 使用static静态成员实现服务器端缓存(导航面包屑)

    返回目录 今天写缓存篇的第一篇文章,在写完目录后,得到了一些朋友的关注,这给我之后的写作带来了无穷的力量,在这里,感谢那几位伙伴,哈哈! 书归正传,今天我带来一个Static静态成员的缓存,其实它也不 ...

  4. 缓存篇(Cache)~第三回 HttpModule实现网页的文件级缓存

    返回目录 再写完缓存篇第一回之后,得到了很多朋友的好评和来信,所以,决定加快步伐,尽快把剩下的文章写完,本篇是第三回,主要介绍使用HttpModule实现的文件级缓存,在看本文之前,大家需要限度Htt ...

  5. 缓存篇~第六回 Microsoft.Practices.EnterpriseLibrary.Caching实现基于方法签名的数据集缓存

    返回目录 这一讲中主要是说EnterpriseLibrary企业级架构里的caching组件,它主要实现了项目缓存功能,它支持四种持久化方式,内存,文件,数据库和自定义,对于持久化不是今天讨论的重要, ...

  6. (转)高性能网站架构之缓存篇—Redis集群搭建

    看过 高性能网站架构之缓存篇--Redis安装配置和高性能网站架构之缓存篇--Redis使用配置端口转发 这两篇文章的,相信你已经对redis有一定的了解,并能够安装上,进行简单的使用了,但是在咱们的 ...

  7. 前端技巧:禁止浏览器static files缓存篇(转)

    前端技巧:禁止浏览器static files缓存篇 由于CSS/JS文件经常需要改动,前端调试时是不希望浏览器缓存这些文件的. 本文记录博主的经验. Meta法 目前在chrome调试还没有遇到问题, ...

  8. Spring Boot 揭秘与实战(二) 数据缓存篇 - Redis Cache

    文章目录 1. Redis Cache 集成 2. 源代码 本文,讲解 Spring Boot 如何集成 Redis Cache,实现缓存. 在阅读「Spring Boot 揭秘与实战(二) 数据缓存 ...

  9. Spring Boot 揭秘与实战(二) 数据缓存篇 - Guava Cache

    文章目录 1. Guava Cache 集成 2. 个性化配置 3. 源代码 本文,讲解 Spring Boot 如何集成 Guava Cache,实现缓存. 在阅读「Spring Boot 揭秘与实 ...

随机推荐

  1. c#一些特殊语法

    1.using 语法 using不仅可以作为导入包,重命名类名.还可以释放资源 using (Pen gridLinePen = new Pen(Color.red)) { e.Graphics.Dr ...

  2. Android Studio安装插件Genymotion

    Android Studio安装插件的方式其实和Eclipse大同小异.废话不多说,直接上图: 区域1:你当前已经安装了的插件 区域2:在线安装 区域3:从硬盘安装,即针对你已经下载好了的插件,可通过 ...

  3. 深入 JAVA里面关于byte数组和String之间的转换问题

    把byte转化成string,必须经过编码.  例如下面一个例子:  importjava.io.UnsupportedEncodingException; publicclass test{ pub ...

  4. myBatis源码之BatchExecutor

    BatchExecutor是实现批处理操作,会将根据相同操作通过判断sql语句和MappedStatement来将执行放到List中,来执行批处理操作. /** * @author Jeff Butl ...

  5. 开源项目管理系统:ProjectForge

    ProjectForge是一个Java编写的开源的基于Web的项目管理解决方案.包括:工时表(Timesheet).费用管理.项目甘特图,控制和管理工程分解结构.集成JiRA做为问题管理系统. 使用的 ...

  6. Android的fuzz测试技术之符号执行浅谈-android学习之旅(82)

    简单的漏洞越来越少,需要改进目前的方法 : 通过符号执行,得出执行路径,然后在进行fuzzy是较为有效的方法之一 1)为待测单元自动地生成可到达的测试数据,即提高测试目标的覆盖率 2)根据特定的漏洞模 ...

  7. C# BarCodeToHTML条码生成类

    来自:http://www.sufeinet.com/forum.php?mod=viewthread&tid=656&extra=page%3D1%26filter%3Dtypeid ...

  8. centos 下安装mysql-5.6.11

    这次是在centos6.4下安装mysql,在安装之前,你要先确定你的linux已经安装了这些包: wget, gcc-c++, ncurses-devel ,cmake, make ,perl 如果 ...

  9. Java-HttpServletResponse-HttpServletResponseWrapper

    //继承ServletResponse,发送回复信息,servlet容器创建一个HttpServletResponse对象,将它作为service函数的参数 public interface Http ...

  10. 网站开发进阶(十四)JS实现二维码生成

    JS实现二维码生成 绪 项目开发原语:已然花费半天的时间,仍旧未能将二维码显示在订单中.但是可以在单个页面中显示二维码,结合到angularjs的控制器中就失效了,自己是真的找不到其中的原因了.费解! ...