Windbg期望mscordacwks.dll的不同版本

Joh*_*020 7 .net debugging windbg

我在尝试使用windbg调试minidump文件时遇到了一个非常奇怪的问题.我已经在我自己的机器上尝试过这种方法,并且在目标机器上运行windbg,从中获取minidump,但结果在两种情况下都是相同的.

在开始时我加载所需的dll,如下所示,请注意,如果我将症状设置为微软符号服务器,则会出现同样的问题.

0:000> .symfix c:\ sos

0:000> .load C:\ Windows\Microsoft.NET\Framework64\v4.0.30319\sos

检查链条的一切看起来都不错,所以我现在去运行!pe并得到一个关于mscordacwks的错误,据我所知,这通常表明我使用的是.net框架的错误版本.但是在我在目标机器上运行它时,情况确实应该不是这样.

然后我做了一个冗长的加载

.cordll -ve -u -l

并获取以下错误消息

CLRDLL:C:\ Windows\Microsoft.NET\Framework\v4.0.30319\mscordacwks.dll:4.0.30319.17929 f:8与所需版本4.0.30319.296不匹配f:8

我不明白为什么windbg正在寻找旧版本的mscordacwks?似乎.296版本是从ms符号服务器下载的clr的版本,但我明确地告诉windbg使用本地版本.

我尝试了这里这里建议的方法,但没有任何作用.任何帮助是极大的赞赏.

Ste*_*son 9

这是因为您在安装了.NET 4.5的计算机上调试.NET 4.0转储.底层调试API在4.0和4.5之间发生了显着变化,因此您无法使用.NET 4.5 SOS.dll调试.NET 4.0转储.我所做的是将.NET 4.0 SOS复制到我的winext目录并在我调试.NET 4.0转储时显式加载它.


Lex*_* Li 9

您是如何尝试WinDbg x64的步骤的:无法调试崩溃转储 - 无法加载数据访问DLL

你应该这样做

  1. 从源计算机复制mscordacwks.dll.
  2. 将其重命名为mscordacwks_AMD64_AMD64_4.0.30319.296.dll.
  3. 将此DLL删除到WinDbg.exe的文件夹中.
  4. 重新初始化调试会话(关闭并重新打开WinDbg).

然后很可能会收到一条错误消息,说WinDbg想要该版本的.NET 4的SOS,你可以

  1. 从源计算机复制sos.dll并将其保存到C:\ temp\sos.dll.
  2. 在WinDbg中,使用.load C:\ temp\sos.dll而不是调用.loadby sos clr.