• [转] 支持源文件索引符号服务器的构建和使用


    当我们开发的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
    第一个文献看起来有理有据,描述了基本过程;不过在细节方面貌似还是有些问题的;
    第三个文献很详细... 

    原文地址:http://blog.sina.com.cn/s/blog_715342050100oxdx.html

  • 相关阅读:
    shell脚本:Kill掉MySQL中所有sleep的client线程
    为什么事务要提交或者回滚?
    MySQL 性能优化
    解决:Reading table information for completion of table and column names
    mysql distinct 用法详解及优化
    MySQL Profiling 的使用
    手把手教你用Strace诊断问题[转]
    mysql,命令导入导出表结构或数据
    八种架构设计模式及其优缺点概述(下)
    mysql多实例配置下,用脚本启动mysql时,出现Please read "Security" section of the manual to find out how to run mysqld as root!
  • 原文地址:https://www.cnblogs.com/txk1452/p/2634030.html
Copyright © 2020-2023  润新知