我在使用新的 .NET 4 System.Runtime.Caching MemoryCache 的 MVC 3 应用程序时遇到问题。我注意到,在一段看似不可预测的时间之后,它会停止缓存内容,并且表现得好像它是空的。考虑一下我直接从 ASP.NET MVC 中的测试 View 中获取的这段代码:
MemoryCache.Default.Set("myname","fred", new CacheItemPolicy() { SlidingExpiration = new TimeSpan(0,5,0) });
Response.Write(MemoryCache.Default["myname"]);
当它工作时,可以预见的是“fred”会被打印出来。但是,当问题开始发生时,尽管使用了 Set()
,MemoryCache.Default["myname"]
的值为 null。我可以通过在 Response.Write() 行上设置断点并使用立即窗口直接设置和读取缓存来证明这一点 - 它只是不会设置它并保持为空!让它再次工作的唯一方法是导致 AppDomain 回收。
有趣的是,当应用程序正常工作时,我可以通过中断 Response.Write()
行并运行 MemoryCache.Default.Dispose()
来引发问题的发生。 。之后,MemoryCache.Default 本身不为 null(这是为什么?),但不会保存其上设置的任何内容。它不会导致任何错误,但不会保存任何内容。
有人可以验证这一点并解释一下吗?正如我相信我已经发现的那样,当应用程序自行停止工作时,有东西正在处置MemoryCache.Default
,但不是我!
更新
好吧,我现在已经厌倦了这个问题! CLRProfiler 似乎不适用于 MVC 3。SciTech 的 CLR 工具很好 - RedGate ANTS 也很好。但他们只告诉我 MemoryCache 对象正在被某物处置!我还证明(通过时间戳打印)页面上应该缓存的 PartialView(由 OutputCacheAttribute 指定)在几分钟后停止缓存 - 每次调用页面时它都会开始刷新。为了澄清环境,我直接在运行 Win 7 Ultimate 的开发工作站上的 IIS 7.5 服务器上运行。上面提到的内存工具表明,就游戏中的对象而言,我只使用了大约 9mb 的内存。
无奈之下,我更改了缓存代码,首先搜索环境 HttpContext 来 Hook 并使用其缓存功能(如果可用)。早期测试表明这是可靠的,但感觉就像是一个令人讨厌的黑客攻击。
我感觉 MemoryCache 和 OutputCache 不保证与 MVC 3 一起使用...
最佳答案
所以,这里有一些新闻。我们对此进行了调查,是的,这是 .NET 4 中的一个错误。
好消息是它已在 .NET 4.5 中修复,因此如果可以的话,将您的安装更新到 .NET 4.5 就可以了。
另一个好消息是,此修复已向后移植到 .NET 4,并将作为 QFE(快速修复...您将应用的一次性修复)提供#578315。它几天前才被向后移植/修复,应该尽快发布。我会尝试确定确切的日期,但很快了。
另一个好消息是,在 QFE 之前的 .NET 4 上有一个解决方法。解决方法很奇怪,但它可以解锁您。
using (ExecutionContext.SuppressFlow()) {
// Create memory cache instance under disabled execution context flow
return new YourCacheThing.GeneralMemoryCache(…);
}
希望这有帮助。
更新:修补程序是 http://support.microsoft.com/kb/2828843您可以在这里请求:https://support.microsoft.com/contactus/emailcontact.aspx?scid=sw;%5BLN%5D;1422
关于asp.net - 内存缓存为空: Returns null after being set,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7422859/