C# 使用WinDbg从MinidDump确定InnerException的行号

C# 使用WinDbg从MinidDump确定InnerException的行号,c#,exception,windbg,sos,C#,Exception,Windbg,Sos,我正在尝试从转储中跟踪NullReferenceException。NullReferenceException不是崩溃异常,而崩溃异常是TargetInvocationException和InnerException,InnerException是NullReferenceException 我在SOS中使用Windbg,我使用命令analyze-v,这给了我NullReferenceException的调用堆栈: EXCEPTION_OBJECT: !pe f6cb150 Exception

我正在尝试从转储中跟踪NullReferenceException。NullReferenceException不是崩溃异常,而崩溃异常是TargetInvocationException和InnerException,InnerException是NullReferenceException

我在SOS中使用Windbg,我使用命令
analyze-v
,这给了我NullReferenceException的调用堆栈:

EXCEPTION_OBJECT: !pe f6cb150
Exception object: 000000000f6cb150
Exception type:   System.NullReferenceException
Message:          Object reference not set to an instance of an object.
InnerException:   <none>
StackTrace (generated):
SP               IP               Function
000000002CD9D8C0 000007FF01E7C639 MyDll!DoSomething2()+0xe99
000000002CD9DBE0 000007FF01E7B11D MyDll!DoSomething1()+0x43d
000000002CD9DD20 000007FF01E7AB11 MyDll!WorkerDoWork(System.Object, System.ComponentModel.DoWorkEventArgs)+0x51
000000002CD9DD80 000007FEEA68A0F2 System_ni!System.ComponentModel.BackgroundWorker.WorkerThreadStart(System.Object)+0x62
请注意!ip2md命令在发生TargetInvocationException的方法的IP上成功

问题

我从这里可以到哪里去缩小DoSomething2中的哪条线正在崩溃? 请注意,我无法复制崩溃,因此我所有的转储都是这个(和几个重复的)

附加注释

  • .NET4.0
  • Windbg版本:6.12.0002.633 AMD64
  • 我是Windbg的新手。所以信息越多越好
编辑1

如果没有正确设置符号,我会得到以下结果:

STACK_TEXT:  
00000000`2cd9d8c0 00000000`ffffffff MyDll!Unknown_0xe99+0xe99
00000000`2cd9dbe0 00000000`ffffffff MyDll!Unknown_0x43d+0x43d
00000000`2cd9dd20 00000000`ffffffff MyDll!Unknown_0x51+0x51
00000000`2cd9dd80 00000000`ffffffff system_ni!    System.ComponentModel.BackgroundWorker.WorkerThreadStart+0x62
当我将其设置为指向我的符号服务器并打开时!sym嘈杂,似乎可以正确加载符号:

0:000> ld MyDll
DBGHELP: C:\Program Files\Debugging Tools for Windows (x64)\MyDll.dll - file not found
SYMSRV:  c:\symbols\MyDll.dll\4F3D6F4B154000\MyDll.dll not found
SYMSRV:  http://msdl.microsoft.com/download/symbols/MyDll.dll/4F3D6F4B154000/MyDll.dll not found
SYMSRV:  \\mysymbolserver\store\Mydll.dll\4F3D6F4B154000\file.ptr
SYMSRV:  MyDll.dl_ from \\mysymbolserver\store: uncompressed
DBGHELP: c:\symbols\MyDll.dll\4F3D6F4B154000\MyDll.dll - OK
DBGENG:  c:\symbols\MyDll.dll\4F3D6F4B154000\MyDll.dll - Mapped image memory
SYMSRV:  c:\symbols\MyDll.pdb\8AFC2BE7529A41289FA9FBCEDB6836161\Mydll.pdb not found
SYMSRV:  http://msdl.microsoft.com/download/symbols/Mydll.pdb/8AFC2BE7529A41289FA9FBCEDB6836161/MyDll.pdb not found
SYMSRV:  \\mysymbolserver\store\MyDll.pdb\8AFC2BE7529A41289FA9FBCEDB6836161\file.ptr
SYMSRV:  MyDll.pd_ from \\mysymbolserver\store: uncompressed
DBGHELP: MyDll - private symbols & lines 
     c:\symbols\MyDll.pdb\8AFC2BE7529A41289FA9FBCEDB6836161\MyDll.pdb
Symbols loaded for MyDll
编辑2

我试过用!名称2ee如下:

0:000> !name2ee MyDll!MyType.DoSomething2
Module:      000007ff004995b8
Assembly:    Autodesk.DataManagement.Client.Framework.Vault.dll
<invalid module token>

我猜所有缺少的条目(那些以“IsnotaMethodDesc”列出的条目)都是由于这不是一个完整的迷你转储。是吗?

看起来WinDbg没有为您的DLL拾取符号。您可以通过设置符号路径并使用
来查看这一点!sym嘈杂
,必要时进行故障排除

我说不出为什么!ip2md在这种情况下不起作用,但是有其他方法可以获取
DoSomething2
的代码。试试
!方法名称上的name2ee
,例如
!名称2ee*!TypeName.DoSomething2
,或者您可以像下面这样通过类型本身获得它!名称2ee*!Namespace.TypeName然后
!dumpmt-md
在从
获得的方法表上!名称2ee


一旦你有了代码,
!u
命令可以显示.NET注释的汇编代码转储。通过使用异常的偏移量,可以确定NullReferenceException的性质

您可能正在使用剥离的PDB文件,这是为发布版本中的项目生成的默认文件。所有文件和行号信息都将从该文件中删除

切换到版本配置、项目+属性、构建选项卡、高级、调试信息=“完整”


顺便说一句,对于发布版本,行号信息不是很准确。抖动优化器会移动代码,因此您需要记住显示的行号是近似值。

在上面的评论中,您提到| |命令会生成“用户迷你转储”。为了正确地调试.NET代码,您需要一个完全转储,它将从| |命令中指示“完全内存用户迷你转储”。我想这是你的问题。如果不访问完整加载程序堆,就不可能将代码地址映射回.NET方法,因此无法获得堆栈跟踪。如果可以重现此问题,请捕获完整转储。您可以使用ADPlus、ProcDump或DebugDiag捕获崩溃时的转储。

谢谢!我想我确实装了符号。如果没有符号,我会得到不同的输出(请参见问题中的编辑)。我将很快尝试其他方法并报告。如果转储不是完全转储,大多数.NET调试命令将无法工作。“我想知道这里的情况是否如此?”史蒂文·约翰逊,有没有办法告诉我这是不是一个完全的垃圾场?这个ip2md命令用于获取最终崩溃发生的to函数的方法描述符。请运行| |命令。我得到:0:000>| |。0满内存用户迷你转储:D:\xyz.DMPOkay,我得到:。0用户迷你转储:C:\mydump.dmpy您不需要符号来获取托管堆栈跟踪。但是,您通常需要完全转储。这是进程的完全转储还是只是一个小转储?是的,缺少条目很可能是由于转储未满造成的。
0:000> !name2ee MyDll!MyType.DoSomething2
Module:      000007ff004995b8
Assembly:    Autodesk.DataManagement.Client.Framework.Vault.dll
<invalid module token>
0:000> !name2ee MyDll.dll!MyNamespace.MyType
Module:      000007ff004995b8
Assembly:    MyDll.dll
Token:       000000000200008c
MethodTable: 000007ff01b2e258
EEClass:     000007ff01b415e0
Name:        MyNamespace.MyType

0:000> !dumpmt -md 7ff01b2e258
EEClass:      000007ff01b415e0
Module:       000007ff004995b8
Name:         MyNamspace.MyType
mdToken:      000000000200008c
File:         C:\Program Files\MyCompany\MyProduct\Bin\MyDll.dll
BaseSize:        0x30
ComponentSize:   0x0
Slots in VTable: 31
Number of IFaces in IFaceMap: 2
--------------------------------------
MethodDesc Table
           Entry       MethodDesc      JIT Name
000007feeb31a2c0 0000000000000000     NONE 0000000000000000 is not a MethodDesc
000007feeb3689f0 0000000000000000     NONE 0000000000000000 is not a MethodDesc
000007feeb3688c0 0000000000000000     NONE 0000000000000000 is not a MethodDesc
000007feeb353440 0000000000000000     NONE 0000000000000000 is not a MethodDesc
000007ff01b01300 0000000000000000     NONE 0000000000000000 is not a MethodDesc
000007ff01e89140 0000000000000000     NONE 0000000000000000 is not a MethodDesc
000007ff01b9c080 0000000000000000     NONE 0000000000000000 is not a MethodDesc
000007ff01f45f40 0000000000000000     NONE 0000000000000000 is not a MethodDesc
000007ff01a9b358 000007ff01b2e128     NONE MyType.DoSomething3()
000007ff01a9b360 000007ff01b2e130     NONE MyType.DoSomething4()
000007ff01a9b368 000007ff01b2e138     NONE MyType.DoSomething5()
000007ff01e79800 0000000000000000     NONE 0000000000000000 is not a MethodDesc
000007ff020fea80 0000000000000000     NONE 0000000000000000 is not a MethodDesc
000007ff01a9b3b0 000007ff01b2e1b0     NONE MyType.DoSomething6()
000007ff01a9b3b8 000007ff01b2e1b8     NONE MyType.DoSomething7()
000007ff01a9b328 000007ff01b2e0f0     NONE MyType..ctor()
000007ff01b01280 0000000000000000     NONE 0000000000000000 is not a MethodDesc
000007ff01e7a810 0000000000000000     NONE 0000000000000000 is not a MethodDesc
000007ff01e7aac0 0000000000000000     NONE 0000000000000000 is not a MethodDesc
000007ff01e83240 0000000000000000     NONE 0000000000000000 is not a MethodDesc
000007ff01f19520 000007ff01b2e178      JIT MyType.RunWorkerCompleted(System.Object, System.ComponentModel.RunWorkerCompletedEventArgs)
000007ff01e7ace0 0000000000000000      JIT 0000000000000000 is not a MethodDesc
000007ff01e7b7a0 0000000000000000      JIT 0000000000000000 is not a MethodDesc
000007ff01e7b710 0000000000000000      JIT 0000000000000000 is not a MethodDesc
000007ff01e7d2b0 0000000000000000      JIT 0000000000000000 is not a MethodDesc
000007ff01b015f0 0000000000000000      JIT 0000000000000000 is not a MethodDesc
000007ff01b88ce0 0000000000000000      JIT 0000000000000000 is not a MethodDesc
000007ff01a9b3e0 000007ff01b2e200     NONE MyType.DoSomething8()
000007ff01b921e0 0000000000000000     NONE 0000000000000000 is not a MethodDesc
000007ff01b933b0 0000000000000000     NONE 0000000000000000 is not a MethodDesc
000007ff01b93870 0000000000000000     NONE 0000000000000000 is not a MethodDesc