当我们开发的Windows程序崩溃时,我们常会将Catch到的Dump文件进行分析。
以往当我们拿到一个Dump时,通常是这样做的:
1.确定Dump发生时的版本号;2.找到备份的对应版本的PDB文件;3.必要时再找对应版本的源文件;然而,当发布出去的版本较多时,上述过程是很麻烦的;
建议一个符号服务器可以为我们省去上述麻烦。----以下介绍带源文件索引的符号服务器的创建过程--------:以下是创建符号服务器的过程,使用符号服务器不需要这些工作;以下描述仅适用于源代码服务器为SubVersion的情形,其他源代码服务器的情况,请参考相应资料。1. 准备工作
安装Windows Debugging Tools下载地址:安装Perl
下载地址:安装SubVersion
下载地址:安装SubVersion要注意几点:
Ø 它可以与TortoiseSVN共存;Ø 一定不能安装带本地化语言的版本,必须是英文版;如果安装上述推荐地址的SilkSVN,注意不要选择本地语言选项。为了确定是否安装了英文版,可以在命令行中敲svn help,看输出的是否全部为英文提示;这点尤为重要,而且容易被忽视;将上述软件的安装路径加入到Path环境变量中;注意对于Debugging Tools for Windows,不仅需要把Debugging Tools for Windows目录加入到Path环境变量,还需要将其下面的srcsrv目录也加进去,因为后续执行的svnindex命令等实际上是在srcsrv目录中。2. 为符号文件添加源文件索引
当编译完成后,将符号文件添加到符号服务器之前,需要对符号文件进行处理,在符号文件上加入我们的源文件服务器地址信息;如果没有这一步,那么源文件只能人工自己去找了。执行如下命令行:
Svnindex /debug /symbols="E:\MySource\Symbols" /source=" E:\MySource\"上述的"E:\MySource\Symbols"为符号文件所在路径;" E:\MySource\"为源文件所在路径注意上述两个路径一定必须是全路径,不能是相对路径;这点与若干文献描述不一致,但是我的实践证明,如果是相对路径,这个命令是不能执行成功的。
上述命令的执行结果如下图:上述命令实际上是往符号文件中加入了svn命令,用于下载相应的源文件。要看究竟发生了什么,可以采用srctool命令查看某PDB文件中的信息,如:Srctool e:\MySource\Symbols\OneFile.pdb执行结果类似下图:看到了吧,文件中含svn.exe cat命令,从源文件服务器中将相应revision的文件下载下来。
3. 将符号文件添加到符号服务器
接下来就是把符号文件加入到符号服务器了。很简单,就是一条命令:symstore.exe add /r /f "E:\AliWWAutoPackage\Trunk\SourceCode\setup\release*.pdb" /s "E:\SymbolServer" /t TaoyouSetup /v "1.0.0.1" /compress /d "E:\SymbolServer\SymStore_TaoyouSetup.log" /o上述命令中,/f后的路径是符号文件路径;/s后的路径是符号服务器所在路径;其他命令参数请参考Symstore.exe的命令说明吧。
然后把符号服务器路径设置为文件共享,或者通过HTTP服务器暴露出去,那就是名副其实的"符号服务器"了。以下介绍如何使用符号服务器:
先介绍windbg中的用法。1. 设置符号服务器地址;
如我的设置是这样的:*srv*D:\SymbolCache*http://msdl.microsoft.com/download/symbols;\\YourServer\SymbolServer\后面那部分就是我们的符号服务器地址;2. 设置源文件服务器地址:
同样,可以通过Windbg的菜单File->Source File Path,设置如下:*srv*D:\SourceCache*上述的D:\SourceCache是本地缓存路径,注意自己先把该文件夹建好了;3. 在windbg中打开某dump文件。
如敲入!analyze -v命令,此时就能够显示相应的源文件信息了,如:牛B了吧,如果没有源文件索引,上述信息是不会显示出来的。 不过第一次使用时,windbg会弹出如下安装提示:选择最后一项后,今后就不会出现了。
Visual Studio中的用法更为简单:
在菜单的工具->选项->调试->常规选项中,将如下两个选项勾上:
启用源服务器支持将源服务器诊断信息打印到输出窗口如下图:如此设置后,就可以在VS中打开相应版本的源文件了。参考文献:
第一个文献看起来有理有据,描述了基本过程;不过在细节方面貌似还是有些问题的;第三个文献很详细...
原文地址: