3

我有一个在 Server 2003 下作为服务运行的 64 位应用程序。

当我附加 VS Profiler 或 windbg 时,我看到很多调用堆栈,如下所示。我知道在调试器(或分析器)中生成的进程使用调试堆等......但情况并非如此,因为该服务是由操作系统启动的,我只是附加到它。

我不明白为什么它正在展开堆栈。分析器显示,在这方面花费了可衡量的时间。更多信息:

• 这些是使用 vc9 构建的版本位,在 Server 2003 上运行。

• 系统环境变量_NO_DEBUG_HEAP 设置为1。

• 我正在使用 Microsoft 符号服务器。

为什么要捕获堆栈跟踪?似乎它正在记录它..但我找不到在哪里。

我的目标是验证应用程序是否真的在展开堆栈,如果这是真的,尽量避免它。

有任何想法吗?


调用栈

ntdll!RtlVirtualUnwind
ntdll!RtlpWalkFrameChain
ntdll!RtlCaptureStackBackTrace
ntdll!RtlpCaptureStackTraceForLogging
ntdll!RtlLogStackBackTrace
ntdll!RtlDebugAllocateHeap
ntdll!RtlAllocateHeapSlowly
ntdll!RtlAllocateHeap
MSVCR90!malloc
MSVCR90!operator new
4

2 回答 2

8

可能有人使用gflags.exe来启用此进程或系统范围内的用户堆栈跟踪捕获,或其他需要跟踪 CRT 分配操作的标志。

您应该能够使用此处的信息在注册表中检查这种可能性。

于 2013-01-03T20:00:36.417 回答
0

史蒂夫的回答很好,经过长时间的调查,最终为我们自己的服务器找到了解决方案。我们的情况略有不同,堆栈捕获的原因是由于脚本定期运行 UMDH 捕获。UMDH 将在第一次针对该进程执行时启用堆栈收集。它给出以下警告:

 UMDH has enabled allocation stack collection for the current running process.
于 2014-04-25T21:10:35.447 回答