6

我有一个应用程序,我想使用 Windows 性能分析器对其进行分析。一切正常,但我没有从我的应用程序中获得任何合理的堆栈跟踪。

有问题的应用程序是一个演示应用程序。如果所有检查都结束,这是为了给我一个很好的感觉。然后我想分析另一个应用程序。因为我可以完全控制我的演示应用程序,所以我包含了一些标记函数,它们应该会显示在堆栈跟踪中。

在 Windwos 7 1上运行应用程序时,Process Explorer 会显示我想要分析的部件的正确堆栈跟踪。这是第 7 - 9 行中带有标记函数的堆栈跟踪:

进程资源管理器堆栈跟踪

由于我在 Windows 10 VM 2中安装了所有性能分析工具,因此我开始在那里进行分析。首先要注意:Process Explorer 没有显示正确的堆栈跟踪。我实现的标记功能无处可寻。

尽管如此,我还是使用UIforETWWindows Performance Recorder记录了性能跟踪。在 WPA 中打开它们并专注于目标应用程序时,这是堆栈跟踪:

WPA 堆栈跟踪

我感兴趣的所有信息都丢失了。堆栈显示为<Application>.exe!<Missing ImageId event>

我做错什么了?


如果这给你一个提示,这里是安装的相关软件:

1:Windows 7 计算机已安装 Visual Studio (C#)。

2:Windows 10 VM 没有 Visual Studio,但安装了 WinDBG(预览版)和 Windows Performance Toolkit。

我标记了,因为目标应用程序是用 Delphi 编写的。

4

2 回答 2

6

Windows 10 WPA(以及 Windows 8.1,在较小程度上)放弃了对旧调试符号格式的支持;它现在仅支持自 MSVC 7 以来已成为标准的“RSDS”格式。使用旧符号文件格式的 PE 文件(例如,VB6 生成 NB10 PDB 文件)将导致“缺少 ImageId 事件”错误。

(消息本身在技术上不正确;即使在跟踪文件中也可能有一个 ImageId,但它正在寻找一个 ImageId/DbgID_RSDS 事件,该事件无法为非 RSDS PDB 生成)

于 2018-10-08T20:54:29.387 回答
0

<Missing ImageId event>当会话未与“NT Kernel Logger”合并时也会报告,该“NT Kernel Logger”提供解析符号所需的一些信息。

停止会话的“正确”方法是:

xperf.exe -stop my_trace -stop -d merged_trace.etl

请注意,第二个-stop必须停止另一个会话(隐式“NT Kernel Logger”),-d并将两者合并到merged_trace.etl.

于 2021-06-18T06:57:38.717 回答