当我们开发的Windows程序崩溃时,我们常会将Catch到的Dump文件进行分析。
以往当我们拿到一个Dump时,通常是这样做的:
1.确定Dump发生时的版本号;
2.找到备份的对应版本的PDB文件;
3.必要时再找对应版本的源文件;
然而,当发布出去的版本较多时,上述过程是很麻烦的;
建议一个符号服务器可以为我们省去上述麻烦。
----以下介绍带源文件索引的符号服务器的创建过程--------:
以下是创建符号服务器的过程,使用符号服务器不需要这些工作;
以下描述仅适用于源代码服务器为SubVersion的情形,其他源代码服务器的情况,请参考相应资料。
1. 准备工作
安装Windows Debugging Tools
下载地址:http://www.microsoft.com/whdc/devtools/downloads.mspx
安装Perl
下载地址:http://www.activestate.com/activeperl
安装SubVersion
下载地址:http://www.sliksvn.com/en/download
安装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*http://svn.yourserver.com/
上述的D:\SourceCache是本地缓存路径,注意自己先把该文件夹建好了;
3. 在windbg中打开某dump文件。
如敲入!analyze -v命令,此时就能够显示相应的源文件信息了,如:
牛B了吧,如果没有源文件索引,上述信息是不会显示出来的。
不过第一次使用时,windbg会弹出如下安装提示:
选择最后一项后,今后就不会出现了。
Visual Studio中的用法更为简单:
在菜单的工具->选项->调试->常规选项中,将如下两个选项勾上:
启用源服务器支持
将源服务器诊断信息打印到输出窗口
如下图:
如此设置后,就可以在VS中打开相应版本的源文件了。
参考文献:
http://www.result42.com/howto/symbol-storage-subversion-indexed-symbols
http://www.codeproject.com/KB/debug/sourceindexing.aspx?display=Printhttp://msdn.microsoft.com/en-us/magazine/cc163563.aspx
http://msdn.microsoft.com/en-us/magazine/cc163563.aspx
第一个文献看起来有理有据,描述了基本过程;不过在细节方面貌似还是有些问题的;
第三个文献很详细...