- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章详解.Net缓存之MemoryCahe由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
NetCore中的缓存和System.Runtime.Caching很相似,但是在功能上做了增强,缓存的key支持object类型;提供了泛型支持;可以读缓存和单个缓存项的大小做限定,可以设置缓存的压缩比例.
通过实现微软官方的Microsoft.Extensions.Caching里面的IDistributedCache接口实现缓存集成到ASPNETCore中 。
netcore中缓存相关的类库都在 Microsoft.Extensions.Caching ,使用MemoryCache首先安装包 。
<PackageReference Include="Microsoft.Extensions.Caching.Memory" Version="5.0.0" />
注入 。
public void ConfigureServices(IServiceCollection services) { services.AddControllers(); //添加缓存配置 services.AddMemoryCache(); }
使用 。
private readonly IMemoryCache _cache; public HomeController(IMemoryCache cache) { _cache = cache; } [HttpGet] public string Set() { //写 _cache.Set("login", "4545478244"); return ""; } [HttpGet] public string Get() { //读 var value = _cache.Get("login"); return ""; }
//1.最简单使用方式 _cache.Set("mykey", "myvalue"); //2.绝对过期时间,3秒后过期 _cache.Set("key1", "value1", new DateTimeOffset(DateTime.Now.AddSeconds(3))); //3.绝对过期时间,效果同上 _cache.Set("key2", "value2", TimeSpan.FromSeconds(3)); //4.滑动过期时间,3秒后,即三秒钟内被访问,则重新刷新缓存时间为3秒后 _cache.Set("key3", "value3", new MemoryCacheEntryOptions { SlidingExpiration = TimeSpan.FromSeconds(3), }); Console.WriteLine("-----------暂停2秒"); Thread.Sleep(2000);//暂停2秒 Console.WriteLine($"key1的值:{_cache.Get("key1") ?? "key1被清除"}"); Console.WriteLine($"key2的值:{_cache.Get("key2") ?? "key2被清除"}"); Console.WriteLine($"key3的值:{_cache.Get("key3") ?? "key3被清除"}"); Console.WriteLine("-----------暂停2秒"); Thread.Sleep(2000);//再次暂停2秒 Console.WriteLine($"key1的值:{_cache.Get("key1") ?? "key1被清除"}"); Console.WriteLine($"key2的值:{_cache.Get("key2") ?? "key2被清除"}"); Console.WriteLine($"key3的值:{_cache.Get("key3") ?? "key3被清除"}");
在例子中key1,key2都是使用的绝对过期时间,key3使用的相对过期时间,2秒后第一次访问key1、key2、key3都没过期,其中key3的过期时间刷新了,重新设置为3秒后,所以再次暂停2秒后,key1、key2都过期了,key3仍然存在.
程序运行结果如下:
下边的例子介绍netcore中缓存的常用配置,直接看代码 。
public void ConfigureServices(IServiceCollection services) { services.AddControllers(); services.AddMemoryCache(options => { //缓存大小 options.SizeLimit = 3;//如果设置了该值,那么每个set都必须设置size,并且超过了这个值的大小的会自动销毁 //缓存满了时,压缩20%(即删除20份优先级低的缓存项) options.CompactionPercentage = 0.2; //两秒钟查找一次过期项 options.ExpirationScanFrequency = TimeSpan.FromSeconds(3); }); } [HttpGet] public string TestSize() { //SizeLimit配置3 _cache.Set("item1", "11111", new MemoryCacheEntryOptions { //缓存大小占1份 Size = 2 }); _cache.Set("item2", "22222", new MemoryCacheEntryOptions { Size = 2 }); var item1 = _cache.Get("item1");//输出 11111 var item2 = _cache.Get("item2");//输出 null return ""; } [HttpGet] public string TestOptions() { //单个缓存项的配置 MemoryCacheEntryOptions cacheEntityOps = new MemoryCacheEntryOptions() { //绝对过期时间1 //AbsoluteExpiration = new DateTimeOffset(DateTime.Now.AddSeconds(2)), //绝对过期时间2 //AbsoluteExpirationRelativeToNow=TimeSpan.FromSeconds(3), //相对过期时间 SlidingExpiration = TimeSpan.FromSeconds(3), //优先级,当缓存压缩时会优先清除优先级低的缓存项 Priority = CacheItemPriority.Low,//优先级等级:Low,Normal,High,NeverRemove //缓存大小占1份 Size = 1 }; //注册缓存项被清除时的回调,可以注册多个回调 cacheEntityOps.RegisterPostEvictionCallback((key, value, reason, state) => { Console.WriteLine($"回调函数输出【键:{key},值:{value},被清除的原因:{reason}】"); }); _cache.Set("mykey", "myvalue", cacheEntityOps); Console.WriteLine($"mykey的值:{_cache.Get("mykey") ?? "mykey缓存被清除了"}"); Console.WriteLine("------------------暂停3秒"); Thread.Sleep(3000); Console.WriteLine($"mykey的值:{_cache.Get("mykey") ?? "mykey缓存被清除了"}"); return ""; }
注意netcore中设置缓存和缓存项大小是没有单位的 。
缓存被清空的回调函数可以注册多个(System.Runtime.Caching清除缓存的回调只能是一个).
程序执行结果 。
上边我们已经简单了解了通过滑动过期时间和绝对过期时间来控制缓存的有效性,但是有时缓存的过期与否和时间没有联系,比如我们缓存一个文件的内容,不管缓存多久只要文件没有发生变化缓存都是有效的。在net framework中我们可以通过CacheDependency来控制,在net core中怎么控制呢?net core中我们可以使用IChangeToken接口轻松实现缓存的过期策略。先看一下IChangeToken接口:
public interface IChangeToken { // 是否有变化发生 bool HasChanged { get; } // token是否会调用回调函数,为true时才会有效 bool ActiveChangeCallbacks { get; } // 注册一个回调函数,当有变化时触发回调 IDisposable RegisterChangeCallback(Action<object> callback, object state); }
看一下IChangeToken实现缓存过期策略的两个例子 。
1.3.1 监控文件 。
需要安装组件:Microsoft.Extensions.FileProviders.Physical 。
internal class Program { private static void Main(string[] args) { string fileName = Path.Combine(Environment.CurrentDirectory, "someCacheData.xml"); var fileInfo = new FileInfo(fileName); MemoryCache myCache = new MemoryCache(new MemoryCacheOptions() { }); MemoryCacheEntryOptions cacheEntityOps = new MemoryCacheEntryOptions(); //PollingFileChangeToken是IChangeToken的实现类,通过轮询监控文件变化 cacheEntityOps.AddExpirationToken(new Microsoft.Extensions.FileProviders.Physical.PollingFileChangeToken(fileInfo)); //缓存失效时,回调函数 cacheEntityOps.RegisterPostEvictionCallback((key, value, reason, state) => { Console.WriteLine($"文件【{key}】改动了"); }); //添加缓存,key为文件名,value为文件内容 myCache.Set(fileInfo.Name, File.ReadAllText(fileName), cacheEntityOps); Console.WriteLine(myCache.Get(fileInfo.Name)); } }
PollingFileChangeToken通过轮询来监控文件有没有发生变化,如果文件中的内容发生改变,缓存就会自动过期.
1.3.2 通过代码控制缓存过期 。
class Program { static void Main(string[] args) { MemoryCache memoryCache = new MemoryCache(new MemoryCacheOptions()); MemoryCacheEntryOptions cacheEntityOps = new MemoryCacheEntryOptions(); //使用CancellationChangeToken控制缓存过期 CancellationTokenSource tokenSource = new CancellationTokenSource(); cacheEntityOps.AddExpirationToken(new CancellationChangeToken(tokenSource.Token)); //设置缓存 memoryCache.Set("mykey", "myvalue", cacheEntityOps); Console.WriteLine(memoryCache.Get("mykey") ?? "缓存被清除了"); //通过代码清除缓存 tokenSource.Cancel(); Console.WriteLine(memoryCache.Get("mykey") ?? "缓存被清除了"); } }
tokenSource.Cancel方法发送取消信号,这个方法会触发缓存过期,基于此我们可以通过Cancel方法灵活的实现自定义的缓存策略.
程序执行结果如下:
直接引用我自己简单封装的一个Nuget包(简单封装自己用,不要嘲笑) 。
<PackageReference Include="Common.Cache.MemoryCache" Version="1.1.0" />
注入到容器 。
public void ConfigureServices(IServiceCollection services) { services.AddControllers(); //注入 services.AddMemoryCacheExtension(); }
使用 。
# 在需要使用的地方进行注入 private readonly IMemoryCachimg _cache; public HomeController(IMemoryCachimg cache) { _cache = cache; }
以上就是详解.Net缓存之MemoryCahe的详细内容,更多关于.Net缓存之MemoryCahe的资料请关注我其它相关文章! 。
原文链接:https://www.cnblogs.com/azrng/p/14736061.html 。
最后此篇关于详解.Net缓存之MemoryCahe的文章就讲到这里了,如果你想了解更多关于详解.Net缓存之MemoryCahe的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
创建使用.NET框架的asp.net页面时,访问该页面的客户端是否需要在其计算机上安装.NET框架? IE。用户访问www.fakesite.com/default.aspx,如果他们没有安装框架,他
我阅读了很多不同的博客和 StackOverflow 问题,试图找到我的问题的答案,但最后我找不到任何东西,所以我想自己问这个问题。 我正在构建一个应用程序,其中有一个长时间运行的工作线程,它执行一些
已锁定。这个问题及其答案是locked因为这个问题是题外话,但却具有历史意义。目前不接受新的答案或互动。 我一直想知道为什么微软为这样一个伟大的平台选择了一个如此奇怪的、对搜索引擎不友好的名称。他们就
.Net Framework .Net .NET Standard的区别 1、.NET Framework 在未来.NET Framework或许成为过去时,目前还是有很多地方在使用的。这一套
如果有选择的话,您会走哪条路? ASP.NET Webforms + ASP.NET AJAX 或 ASP.NET MVC + JavaScript Framework of your Choice
我有一个 Web 服务,它通过专用连接通过 https 使用第三方 Web 服务,我应用了 ServicePointManager.ServerCertificateValidationCallbac
为什么我应该选择ASP.NET Web Application (.NET Framework)而不是ASP.NET Core Web Application (.NET Framework)? 我在
我在网络上没有找到任何关于包含 .NET Standard、.NET Core 和 .NET Framework 项目的 .NET 解决方案的公认命名约定。 就我而言,我们在 .NET 框架项目中有以
.NET Compact 是 .NET 的完美子集吗? 假设我考虑了屏幕大小和其他限制并避免了 .NET Compact 不支持的类和方法,或者 .NET Compact 是一个不同且不兼容的 GUI
我已经阅读了所有我能找到的关于 connectionManagement 中的 maxconnection 设置的文章:即 http://support.microsoft.com/kb/821268
我现在正在使用asp.net mvc,想知道使用内置的Json或 Json.Net哪个是更好的选择,但我不确定一个人是否比另一个人有优势。 另外,如果我确实选择沿用Json.Net的路线,那么我应该选
在 Visual Studio 中,您至少可以创建三种不同类型的类库: 类库(.NET Framework) 类库(.NET 标准) 类库(.NET Core) 虽然第一个是我们多年来一直使用的,但我
.NET 和 ASP.NET 之间有什么区别?它们有什么关系? 最佳答案 ASP.Net 基于 .Net 框架构建,提供有关 Web 开发的附加功能。 你可以去看看wikipedia article
在安装更高版本(3.0)之前,我需要安装.net框架1.1和2.0吗?或者单独安装 3.0 框架就足够了,并为在早期框架版本上编写的软件提供支持?谢谢 ,丽然 最佳答案 不,您不必安装以前的框架。 我
我正在开发一个项目,人们可以“更新”类别,例如更改类别的名称。我收到以下消息 This is called after clicking update 按钮 with the SQL statemen
.NET 类 System.Net.CookieContainer 线程安全吗? --更新:交 key 答复-- 是否有任何方法可以确保异步请求期间修改的变量(即 HttpWebRequest.Coo
我正在使用 JScript.NET 在我编写的 C# WinForms 应用程序中编写脚本。它工作得很好,但我只是尝试在脚本中放置一些异常处理,但我无法弄清楚如何判断我的 C# 代码抛出了哪种类型的异
我需要你的帮助, 比如我有一个小数类型的变量,我想这样取整。 例如 3.0 = 3 3.1 = 4 3.2 = 4 3.3 = 4 3.4 = 4 3.5 = 4 3.6 = 4 3.7 = 4 3.
我使用过这样的代码:http://msdn.microsoft.com/en-us/library/dw70f090.aspx在 ASP.NET 中工作之前访问数据库(2-3 年前)。我没有意识到我正
自 ConfigurationManager .NET Standard 中不存在,检索正在执行的程序集的应用程序设置的最佳方法是什么,无论是 web.config或 appSettings.{env
我是一名优秀的程序员,十分优秀!