我一直在对生产ASP.NET Web应用程序运行负载测试,并且看到在堆上创建了大量的System.WeakReferences。在负载下大约15分钟内,托管堆内存大约增加到3GB,我有大约5,000,000个对System.WeakReference的引用。执行所有代的强制垃圾收集不会释放这些引用。
我见过有关__ENCLIST助手类的帖子,如果在调试中编译程序集,可以为所有创建的对象创建WeakReferences,起初我认为这是问题,但已经验证所有已部署的程序集都是在发布版本中构建的。 / p>
我一直在使用WinDbg来调试这个过程,这里是!dumpheap -stat
的最后几行
000007fef788e0c0 39253 18510000 System.Collections.Hashtable+bucket[] 00000000021bf120 94336 151023192 Free 000007fef7887e98 5959 189838752 System.Char[] 000007fef7874390 517429 589750224 System.Object[] 000007fef78865a0 1531190 1230824112 System.String 000007fef787dab8 51723338 1655146816 System.WeakReference
正如您所看到的,这些System.WeakReferences消耗了大约1.5GB的内存。
有没有人知道什么可以创建所有这些WeakReferences?
答案 0 :(得分:4)
事实证明,由于动态创建了大量System.Diagnostics.TraceSwitch实例,我发生了System.WeakReference泄漏,内部TraceSource / TraceSwitch将WeakReference分配给新的TraceSource / TraceSwitch并将WeakReference放入列表中。尽管WeakReference允许对TraceSource / TraceSwitch进行垃圾回收,但WeakReference本身永远不会被释放,从而导致内存泄漏。
可以在这里找到更多信息
http://msdn.microsoft.com/en-us/library/system.diagnostics.tracesource(VS.80).aspx