[英]Finding memory leak in ASP.NET website with ANTS Memory Profiler?
我有一个存在内存泄漏的ASP.NET FRAMEWORK 4.0网站。 为了找到它,我已经安装了ANTS Memory Profiler。
这就是我要做的:
这将显示仍保留的类,例如
sites_mypage_default_asx - 10 320 bytes and 10 live instances
usercontrols_common_pagehead_ascx - 928 bytes and 4 live instances
等等
我相信/希望这些是GC将清除的类
但这不是大面积的地方,我必须取消选中带源代码的类以获得真正的大类。 例如(按实时大小(字节)排序
string - 1 890 292 bytes
RuntimeMethodInfo - 990 976 bytes
RuntimePropertyInfo - 604 136 bytes
Hastable+bucket[] - 413 712 bytes
等等。
问题在于,我对此无能为力,在打开“实例”关系图时,我只会看到“系统”。 上课,没有关于我的网站在哪里的信息。
当检查带有源的类时,我发现一个大的内存泄漏可以解决(在上面的运行之前)。
但是我不知道下一步该怎么做? 为什么我的网站仍然占用350 MB? 350 MB的数据是很多数据,我看不到我缓存了这么多数据!
我下一步应该怎么做?
它不一定是内存泄漏,只是内存压力不足以使垃圾回收器执行更全面的工作。 要全面调查此问题并检查是否是真正的内存泄漏,您应该使用平均流量对您的网页进行长时间的负载测试。 如果幸运的话,可以使用Visual Studio Ultimate负载测试,也可以使用开源LoadUI项目。 在此测试期间,请观察性能计数器:
# Bytes in all Heaps
和所有Gen # heap size
# Bytes in all Heaps
, Process : Working Set
和Process : Private bytes
经过几个小时的测试,您将清楚地看到内存消耗的趋势。 如果超过某个阈值,则可能会定期释放它。 但是,如果内存消耗一直在增长,那么您将有一个更可能的内存泄漏假设。 然后在内存泄漏结束时对w3wp
进程进行完整的内存转储,并尝试进一步调查。
因为我是WinDbg的忠实拥护者 (它比任何基于GUI的商业工具都更快,更详细且更便宜),所以建议您使用它。 与Psscor2或Psscor4扩展名一起使用(取决于应用程序使用的版本)。 设置调试环境(安装WinDbg并将其复制到其文件夹Psscor文件)之后,创建该过程的转储。 您可以轻松地做到这一点,例如借助Procdump工具:
procdump -ma <PID>
然后使用File-> Open Crush Dump选项加载转储。 加载适当的Psscor版本:
.load psscor4
然后执行命令以从Microsoft服务器下载符号(如果需要),请确保您具有Internet连接:
!symfix
从现在开始,您应该可以访问很多非常有趣的命令(寻找!help
列出它们)。 要查看每种类型的内存使用情况:
!dumpheap -stat
这将导致一长串类型及其内存使用情况按升序排序:
...
0x79b56d84 297,724 12,308,164 SomeNamespace.SomeObject
0x6983ad6c 1,177 19,751,856 SomeNamespace.SomeClass[]
0x79ba4aa0 6,544 46,300,516 System.Byte[]
0x001027a0 527 69,152,092 Free
0x79b9fb08 1,127,896 82,456,640 System.String
要查看整体内存使用情况( iu
表示还将包括未root用户的对象):
!heapstat -iu
Heap Gen0 Gen1 Gen2 LOH
Heap0 6594540 1488744 24322236 19164192
Heap1 8360908 951312 30822196 14358048
Heap2 8207144 386488 23198448 16078256
Heap3 4299844 453440 36015332 16125560
Total 39615576 5301708 179028460 93254272
Free space: Percentage
Heap0 4868516 12 3512 8692736SOH: 15% LOH: 45%
Heap1 7221256 12 66200 5232904SOH: 18% LOH: 36%
Heap2 7518052 12 520 7677824SOH: 23% LOH: 47%
Heap3 3578232 12 6606504 4098640SOH: 24% LOH: 25%
Total 28807516 72 8353592 31990912
Unrooted objects: Percentage
Heap0 1688812 258828 8905748 4019992SOH: 33% LOH: 20%
Heap1 1052548 270796 9983932 5625984SOH: 28% LOH: 39%
Heap2 503560 267112 7697632 4596792SOH: 26% LOH: 28%
Heap3 571776 235440 8453980 5205176SOH: 22% LOH: 32%
Total 9691432 2179788 53539772 32143328
这些信息肯定会导致您得出一些结论,但是显然可以进行进一步的调查,所以请不要犹豫。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.