gpt4 book ai didi

c# - 使用 ANTS Memory Profiler 在 ASP.NET 网站中查找内存泄漏?

转载 作者:行者123 更新时间:2023-11-30 22:11:17 24 4
gpt4 key购买 nike

我有一个存在内存泄漏的 ASP.NET FRAMEWORK 4.0 网站。为了找到它,我安装了 ANTS Memory Profiler。

这就是我所做的:

  1. 在 IIS7 中托管网站
  2. 启动 Ants Memory Profiler 8.1
  3. 设置我们正在分析 IIS 网站并声明此网页的 URL(内置版本)
  4. 开始测试并让网页启动(大量缓存所以大约 1 分钟)
  5. 在第一页加载稳定后拍摄内存快照
  6. 重新加载第一页很多,看到内存从 110 MB(专用字节/工作集 - 专用)增加到 270 MB
  7. 访问网页上的很多页面,看到它增加到 360 MB
  8. 再推一点,就不再加注了
  9. 获取内存快照并单击类列表(检查类与来源)

这将显示仍然保留的类,例如

sites_mypage_default_asx - 10 320 bytes and 10 live instances
usercontrols_common_pagehead_ascx - 928 bytes and 4 live instances

等等

我相信/希望这些是将被 GC 清理的类

但这不是大脚印所在的地方,我必须取消选中带有源的类才能获得真正大的脚印。例如(按 Live 大小(字节)排序

string - 1 890 292 bytes
RuntimeMethodInfo - 990 976 bytes
RuntimePropertyInfo - 604 136 bytes
Hastable+bucket[] - 413 712 bytes

等等。

问题是我对此无能为力,打开实例关系图时我只会看到 System.在我的网站上没有关于类(class)的信息。

当检查带有源代码的类时,我发现了一个可以修复的大内存泄漏(这是在上述运行之前)。

但我不知道下一步该怎么做?为什么我的网站仍然占用 350 MB? 350 MB 的数据是很多数据,我看不到我缓存了这么多数据!?

下一步应该做什么?

最佳答案

不一定是内存泄漏,只是内存压力不足以让垃圾收集器做更全面的工作。要全面调查此问题并检查它是否是真正的内存泄漏,您应该使用平均流量对您的网页进行长时间运行的负载测试。如果你有幸拥有它或开源 Visual Studio Ultimate Load Testing 项目,你可以使用 LoadUI。在此测试期间观察性能计数器:

  • .NET Memory 组计数器,尤其是 # Bytes in all Heaps 和所有 Gen # heap size
  • Process : Working SetProcess : Private bytes

经过几个小时的这样的测试,你会清楚地看到内存消耗的趋势。如果超过某个阈值,它可能会定期发布。但是,如果内存消耗会一直增长,您将更有可能假设内存泄漏。然后在内存泄漏结束时获取 w3wp 进程的完整内存转储,并尝试进一步调查。

由于我是 WinDbg 的忠实粉丝(它比任何基于 GUI 的商业工具更快、更详细且更便宜),我建议您使用它。将它与 Psscor2Psscor4 扩展一起使用(取决于您的应用程序使用的版本)。设置调试环境(安装 WinDbg 并将 Psscor 文件复制到其文件夹)后,创建进程转储。例如,您可以借助 Procdump 工具轻松完成此操作:

procdump -ma <PID>

然后使用 File -> Open Crush Dump 选项加载转储。加载适当版本的 Psscor:

.load psscor4

然后执行命令从 Microsoft 服务器下载符号(如果需要),确保您有互联网连接:

!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 意味着还将包括无根对象):

!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

这些信息肯定会让您得出一些结论,但显然有可能进行进一步调查,所以请不要犹豫。

关于c# - 使用 ANTS Memory Profiler 在 ASP.NET 网站中查找内存泄漏?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20311422/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com