Windbg符号错误

时间:2017-03-09 18:39:55

标签: windbg

我尝试使用WinDbg调试应用程序。服务器无法访问Internet,因此我无法使用Microsoft Symbol服务器。我继续下载了Server 2012 R2 Retail的符号。将它们移动到服务器,并安装到C:\ Symbols。

当我尝试运行调试器时,我得到以下输出。

CommandLine: C:\actionsync\ActionSync\ActionSync.exe

************* Symbol Path validation summary **************
Response                         Time (ms)     Location 
Deferred                                       srv*
DBGHELP: Symbol Search Path: .sympath srv*c:\symbols*

************* Symbol Path validation summary **************
Response                         Time (ms)     Location
Deferred                                       .sympath srv*c:\Symbols*
DBGHELP: Symbol Search Path: .sympath srv*c:\symbols*
DBGHELP: Symbol Search Path: .sympath srv*c:\symbols*
Symbol search path is: .sympath srv*c:\Symbols*
Executable search path is: srv*
DBGHELP: SharedUserData - virtual symbol module
ModLoad: 00ec0000 00ecc000   ActionSync.exe
ModLoad: 77120000 7728f000   ntdll.dll
ModLoad: 6fc30000 6fc86000   C:\Windows\SysWOW64\MSCOREE.DLL
ModLoad: 74de0000 74f20000   C:\Windows\SysWOW64\KERNEL32.dll
ModLoad: 74f20000 74ff7000   C:\Windows\SysWOW64\KERNELBASE.dll
(1054.478): Break instruction exception - code 80000003 (first chance)
DBGHELP: Invalid path: '.sympath srv*c:\symbols*'
DBGHELP: C:\Windows\SYSTEM32\wntdll.pdb - file not found
DBGHELP: wntdll.pdb - file not found
*** ERROR: Symbol file could not be found.  Defaulted to export symbols for ntdll.dll - 
DBGHELP: ntdll - export symbols
eax=00000000 ebx=00000000 ecx=7fdc0000 edx=00000000 esi=7ee16000 edi=00000000
eip=771d3c7d esp=0104f2f4 ebp=0104f320 iopl=0         nv up ei pl zr na pe nc
cs=0023  ss=002b  ds=002b  es=002b  fs=0053  gs=002b             efl=00000246
ntdll!LdrInitShimEngineDynamic+0x6dd:
771d3c7d cc              int     3

我对使用WinDbg完全不熟悉。另外,我无法在这台机器上安装VS.

据我所知,我已正确设置所有内容,但我仍然无法调试此应用程序。

任何帮助都将不胜感激。

编辑1:

我根据Thomas Weller的评论更新了符号路径

这是输出

0:000> .sympath
Symbol search path is: .sympath srv*c:\Symbols*
Expanded Symbol search path is: .sympath srv*c:\symbols*

************* Symbol Path validation summary **************
Response                         Time (ms)     Location
Deferred                                       .sympath srv*c:\Symbols*
Error: Change all symbol paths attempts to access '.sympath c:\symbols' failed: 0x7b - The filename, directory name, or volume label syntax is incorrect.

************* Symbol Path validation summary **************
Response                         Time (ms)     Location
Error                            16            .sympath c:\symbols
DBGHELP: Symbol Search Path: .sympath c:\symbols
DBGHELP: Symbol Search Path: .sympath c:\symbols
0:000> .reload
Reloading current modules
.....
DBGHELP: Invalid path: '.sympath c:\symbols'
DBGHELP: C:\Windows\SYSTEM32\wntdll.pdb - file not found
DBGHELP: wntdll.pdb - file not found
*** ERROR: Symbol file could not be found.  Defaulted to export symbols for ntdll.dll - 
DBGHELP: ntdll - export symbols

************* Symbol Loading Error Summary **************
Module name            Error
ntdll                  All symbol search paths were invalid
            Please check your symbol search path.


The following location did not respond and were excluded during symbol loading:
.sympath c:\symbols

编辑2:

所以,似乎这种同情是区分大小写的。

我更新了同情C:\Symbols

这是输出。

************* Symbol Path validation summary **************
Response                         Time (ms)     Location
OK                                             c:\Symbols
DBGHELP: Symbol Search Path: c:\symbols
DBGHELP: Symbol Search Path: c:\symbols
0:000> .reload
Reloading current modules
.....
DBGHELP: c:\symbols\wntdll.pdb - file not found
DBGHELP: c:\symbols\dll\wntdll.pdb - file not found
DBGHELP: c:\symbols\symbols\dll\wntdll.pdb - file not found
DBGHELP: C:\Windows\SYSTEM32\wntdll.pdb - file not found
DBGHELP: wntdll.pdb - file not found
*** ERROR: Symbol file could not be found.  Defaulted to export symbols for ntdll.dll - 
DBGHELP: ntdll - export symbols

************* Symbol Loading Error Summary **************
Module name            Error
ntdll                  PDB not found : c:\symbols\symbols\dll\wntdll.pdb
            Unable to locate the .pdb file in this location

1 个答案:

答案 0 :(得分:2)

对于这两种解决方案,您需要一份WinDbg(不一定是安装)。您在WinDbg文件夹中找到symchk

特定转储/特定调试会话的解决方案

  1. 在正在调试的计算机上,使用.dump创建故障转储文件。如果您已有崩溃转储文件,请跳过此步骤。

  2. 在命令提示符处,创建清单文件,即包含有关要下载的符号的信息的文件

    symchk /id <dumpfile>.dmp /om D:\symbols.manifest
    

    /id用于input = dump

    /om用于输出=清单

  3. 将该清单文件传输到具有Internet访问权限的计算机上。

  4. 在Internet计算机上运行

    symchk /im X:\symbols.manifest /s srv*X:\downloadedsymbols\*http://msdl.microsoft.com/download/symbols /od
    

    在命令提示符下。

    /im用于输入=清单

    /od用于输出详细信息(如详细信息)

  5. 将符号传回设备,无法访问Internet。将它们复制到新文件夹,例如c:\downloadedsymbols,而不是c:\symbols。请勿使用现有的符号路径,因为n层布局可能不匹配。

  6. 在WinDbg中打开崩溃转储。

  7. 修复符号

    .sympath C:\downloadedsymbols
    

    也许

    .reload /f
    
  8. 用于检索没有Internet的机器的所有符号的解决方案

    注意:此过程可能需要很长时间,因为它可能会下载数千个符号

    1. 在命令提示符下,运行

      symchk /r /if %windir% /om D:\windir.manifest
      

      /r用于递归

      /if适用于input = files

      /om用于输出=清单

    2. 将该清单文件传输到可以访问Internet的其他计算机上。

    3. 在Internet计算机上,运行

      symchk /im X:\windir.manifest /s srv*X:\winsymbols\*http://msdl.microsoft.com/download/symbols /od
      

      /im用于输入=清单

      /od用于输出详细信息(如详细信息)

    4. 将符号传回设备,无法访问Internet。将它们复制到新文件夹,例如c:\winsymbols,而不是c:\symbols。请勿使用现有的符号路径,因为n层布局可能不匹配。

    5. 使用符号

      .sympath C:\winsymbols
      .reload