15

我们有一个在 .Net 4、Windows 2008 R2 上运行的混合模式汇编应用程序 (MFC+WinForms),它在一个线程上持续使用 100% cpu。

使用 ProcessExplorer,我们在繁忙的线程上看到以下堆栈。我们还可以看到另外 10 个线程仅使用 0.01% 的 CPU 运行 clr.dll!StrongNameSignatureVerification。

旋转线程不会阻止应用程序的其余部分运行,但会浪费 CPU 时间。

繁忙线程的堆栈跟踪如下:

ntoskrnl.exe!IoAcquireRemoveLockEx+0xe7
ntoskrnl.exe!memset+0x22a
ntoskrnl.exe!KeWaitForSingleObject+0x2cb
ntoskrnl.exe!KeDetachProcess+0x120d
ntoskrnl.exe!PsReturnProcessNonPagedPoolQuota+0x3a3
ntoskrnl.exe!CcSetDirtyPinnedData+0x433
mscorlib.ni.dll+0x2b066a
mscorlib.ni.dll+0x2317ac
mscorlib.ni.dll+0x2b066a
mscorlib.ni.dll+0x2317ac
mscorlib.ni.dll+0x26ccf7
mscorlib.ni.dll+0x237fc4
mscorlib.ni.dll+0x26cc3c
clr.dll+0x21bb
clr.dll!CoUninitializeEE+0xee9b
clr.dll!CoUninitializeEE+0x11463
clr.dll!CoUninitializeEE+0x114dc
clr.dll!CoUninitializeEE+0x1154b
clr.dll!StrongNameErrorInfo+0xa638
clr.dll!StrongNameSignatureVerification+0x144fb
clr.dll!StrongNameSignatureVerification+0x1457d
clr.dll!StrongNameSignatureVerification+0x14638
clr.dll!StrongNameSignatureVerification+0x146d2
clr.dll!StrongNameErrorInfo+0x9977
clr.dll!StrongNameErrorInfo+0xa5bc
clr.dll!StrongNameErrorInfo+0xa553
clr.dll!StrongNameErrorInfo+0xa517
clr.dll!StrongNameErrorInfo+0xa151
clr.dll!StrongNameErrorInfo+0x9501
clr.dll!StrongNameErrorInfo+0xad67
clr.dll!StrongNameSignatureVerification+0x164d9
ntdll.dll!RtlCreateUserProcess+0x8c
ntdll.dll!RtlCreateProcessParameters+0x4e

我能找到的唯一类似帐户是在这个问题中:clr.sll!StrongNameSignatureVerification CPU 消耗虽然线程似乎已经变冷了。

我们不签署我们的程序集并愿意信任它们,有没有办法完全禁用强名称验证?

4

2 回答 2

15

clr.dll!StrongNameSignatureVerification+0x164d9

这并不像你认为的那样。标识符右侧的数字很重要,它给出了经过 StrongNameSignatureVerification 函数地址的已知位置的字节数。那是 91353 字节,很多。您可以从中看出的唯一一件事是它没有执行 StrongNameSignatureVerification,该函数没有那么长。堆栈跟踪中的其余标识符同样不可靠。

问题是调试器没有这些 DLL 的 PDB 文件。它只能发现导出函数的地址,对中间的所有函数知之甚少。如果偏移量小于大约 0x100 字节,您只能信任显示的名称。给予或接受。

您需要获取这些 PDB 文件才能了解实际情况。这需要启用 Microsoft 符号服务器。当您开始调试时,调试器将从该服务器下载所需的 PDB 文件。您现在将获得更可靠的符号,让您更好地了解真正执行的代码。

启用符号服务器很容易,MSDN 页面在这里

于 2013-03-01T06:08:09.787 回答
1

您可以考虑使用 Visual Studio 中的分析工具来识别代码中可能导致此问题的热点。要获得对 .net CLR 的符号支持,请参阅此链接。

http://blogs.msdn.com/b/sburke/archive/2008/01/16/configuring-visual-studio-to-debug-net-framework-source-code.aspx

于 2013-03-02T16:18:57.233 回答