每次调用特定方法时,我都会尝试使用调试诊断工具来创建 Minidump。
我从简单的控制台应用程序开始:
namespace FastFailApp {
class Program {
static void Main(string[] args) {
Console.WriteLine("Starting...");
for (int i = 0; i < 20; i++) {
Console.Write(".");
Thread.Sleep(1000);
}
Environment.FailFast("Not so unexpected failure...");
}
}
}
然后我在 DebugDiag 中创建规则以在每次Program.Main
调用时创建 minidump:
不幸的是,它不起作用,在 DebugDiag 日志中我收到消息:
[12/9/2015 8:05:15 PM] Attempting to set managed breakpoint at FailFastApp.dll!FailFastApp.Program.Main
[12/9/2015 8:05:15 PM] bpID = -2
[12/9/2015 8:05:15 PM] Current Breakpoint List(BL)
SYMSRV: https://msdl.microsoft.com/download/symbols/kernel32.pdb/996C94DB18DE43688CA110D2FF25B8542/kernel32.pdb not found
SYMSRV: C:\Program Files\DebugDiag\sym\kernel32.pdb\996C94DB18DE43688CA110D2FF25B8542\kernel32.pdb not found
DBGHELP: C:\Windows\system32\kernel32.pdb - file not found
DBGHELP: kernel32.pdb - file not found
*** ERROR: Symbol file could not be found. Defaulted to export symbols for C:\Windows\system32\KERNEL32.dll -
DBGHELP: KERNEL32 - export symbols
SYMSRV: https://msdl.microsoft.com/download/symbols/ntdll.pdb/6048FDB62DCD41C18835594844CE71432/ntdll.pdb not found
SYMSRV: C:\Program Files\DebugDiag\sym\ntdll.pdb\6048FDB62DCD41C18835594844CE71432\ntdll.pdb not found
DBGHELP: C:\Windows\SYSTEM32\ntdll.pdb - file not found
DBGHELP: ntdll.pdb - file not found
*** ERROR: Symbol file could not be found. Defaulted to export symbols for C:\Windows\SYSTEM32\ntdll.dll -
DBGHELP: ntdll - export symbols
[12/9/2015 8:05:15 PM] Thread exited. Exiting thread system id - System ID: 3568. Exit code - 0x00000000
CLR: Managed code called FailFast, saying "Not so unexpected failure..."
我已经在 DebugDiag 中设置了符号服务器,并使用 WinDBG 检查了此配置:
有没有人有什么建议?
PS。我尝试调试的应用程序是 64 位的。我尝试将当前进程目录(带有 pdb 文件)添加到符号路径,并使用各种格式的断点表达式(如Module!Class::Method
or Module.dll!Class.Method(OtherType)
)但没有成功。