新书推介:《语义网技术体系》
作者:瞿裕忠,胡伟,程龚
   XML论坛     W3CHINA.ORG讨论区     计算机科学论坛     SOAChina论坛     Blog     开放翻译计划     新浪微博  
 
  • 首页
  • 登录
  • 注册
  • 软件下载
  • 资料下载
  • 核心成员
  • 帮助
  •   Add to Google

    >> 本版讨论.NET,C#,ASP,VB技术
    [返回] 中文XML论坛 - 专业的XML技术讨论区计算机技术与应用『 Dot NET,C#,ASP,VB 』 → 用WinDbg探索CLR世界[1] - 安装与环境配置 查看新帖用户列表

      发表一个新主题  发表一个新投票  回复主题  (订阅本版) 您是本帖的第 6029 个阅读者浏览上一篇主题  刷新本主题   树形显示贴子 浏览下一篇主题
     * 贴子主题: 用WinDbg探索CLR世界[1] - 安装与环境配置 举报  打印  推荐  IE收藏夹 
       本主题类别:     
     admin 帅哥哟,离线,有人找我吗?
      
      
      
      威望:9
      头衔:W3China站长
      等级:计算机硕士学位(管理员)
      文章:5255
      积分:18406
      门派:W3CHINA.ORG
      注册:2003/10/5

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给admin发送一个短消息 把admin加入好友 查看admin的个人资料 搜索admin在『 Dot NET,C#,ASP,VB 』的所有贴子 点击这里发送电邮给admin  访问admin的主页 引用回复这个贴子 回复这个贴子 查看admin的博客楼主
    发贴心情 用WinDbg探索CLR世界[1] - 安装与环境配置


    发信人: flier (小海 [寻找风车中]), 信区: DotNET
    标  题: 用WinDbg探索CLR世界[1] - 安装与环境配置
    发信站: BBS 水木清华站 (Thu Feb 26 20:11:27 2004), 转信

    http://www.blogcn.com/user8/flier_lu/main.asp?id=1270368

    用WinDbg探索CLR世界[1] - 安装与环境配置

        一直以来,我对CLR的分析都是基于MSDN、.NET Framework SDK自带文档和Rotor项目提供的源代码进行静态分析,辅以自己写的一些小例子或对Rotor的修修补补,来进行有限度的动态分析。虽然也用SoftIce跟踪过某些核心函数的机制,但感觉实在是太痛苦了,呵呵。
        最近偶然之间发现我的偶像John Robbins在MSDN的BugSlayer上发表的一篇文章<SOS: It's Not Just an ABBA Song Anymore>,才发现原来用WinDbg可以如此方便的动态分析CLR的运行机制。

        首先,需要下载并安装Microsoft Debugging Tools[/url];最好还能下载并安装当前操作系统相应的Windows Symbol Packages。
        然后,配置系统环境变量,让搜索路径指向系统.NET Framework的安装目录,既sos.dll所在目录

        set PATH=%PATH%;E:\WINDOWS\Microsoft.NET\Framework\v1.1.4322

        启动WinDbg之后,在File/Symbol Search Path选项中加入符号文件的安装目录,如

        E:\WINDOWS\Symbols;E:\VS2003\SDK\v1.1\symbols

        或者设置系统环境变量_NT_SYMBOL_PATH(需要重起WinDbg)

        set _NT_SYMBOL_PATH=E:\WINDOWS\Symbols;E:\VS2003\SDK\v1.1\symbols

        最后,在File菜单中,用Open Executable打开一个CLR程序或者用Attach to a process附加到一个正在运行的CLR程序上。

        配置好WinDbg之后,如果打开一个新可执行程序,WinDbg会自动断点到入口,则继续运行再Break;如附加到进程则直接Break。
        然后在最下方命令行上输入系统命令 .load sos 命令载入外部扩展sos.dll。如果配置系统路径正确则这里不会有任何反应,可以继续用系统命令 .chain 查看当前载入的扩展。如下显示则表示sos.dll成功载入。

    以下为引用:

    0:005> .chain
    Extension DLL search Path:
        E:\MS\PlatformSDK\Debugging Tools\winext;...;E:\WINDOWS\Microsoft.NET\Framework\v1.1.4322
    Extension DLL chain:
        sos: API 1.0.0, built Fri Feb 21 10:47:40 2003
            [path: E:\WINDOWS\Microsoft.NET\Framework\v1.1.4322\sos.dll]
        dbghelp: image 6.3.0005.1, API 6.0.6, built Fri Oct 24 02:11:02 2003
            [path: E:\MS\PlatformSDK\Debugging Tools\dbghelp.dll]
        ext: image 6.3.0005.1, API 1.0.0, built Fri Oct 24 09:06:45 2003
            [path: E:\MS\PlatformSDK\Debugging Tools\winext\ext.dll]
        exts: image 6.3.0005.1, API 1.0.0, built Fri Oct 24 02:10:39 2003
            [path: E:\MS\PlatformSDK\Debugging Tools\WINXP\exts.dll]
        uext: image 6.3.0005.1, API 1.0.0, built Fri Oct 24 02:10:54 2003
            [path: E:\MS\PlatformSDK\Debugging Tools\winext\uext.dll]
        ntsdexts: image 6.0.4044.0, API 1.0.0, built Wed Oct 22 02:13:21 2003
            [path: E:\MS\PlatformSDK\Debugging Tools\WINXP\ntsdexts.dll]
      



        在载入sos.dll之后,可以用 lm 命令看看当前有哪些模块被载入内存,如

    以下为引用:

    0:005> lm
    start    end        module name
    ...
    77f30000 77ffa000   ntdll        (export symbols)       E:\WINDOWS\system32\ntdll.dll
    79000000 79010000   ConfigWizards     (deferred)
    79040000 79085000   fusion       (deferred)
    79170000 79196000   mscoree      (deferred)
    791b0000 79412000   mscorwks     (deferred)
    ...
      



        对希望进行分析的模块,可以用ld命令载入相应的调试符号文件(如果有的话,呵呵)。
        如果符号文件搜索路径配置正确的话,可以看到提示

    以下为引用:

    0:005> ld mscorjit
    Symbols loaded for MSCORJIT
      



        此时再用lm可以看到

    以下为引用:

    ...
    79430000 7947c000   MSCORJIT     (pdb symbols)          E:\VS2003\SDK\v1.1\symbols\mscorjit.pdb
    ...
      



        如果符号文件搜索路径配置错误,或者此模块没有调试符号文件,则会载入.dll的export表

    以下为引用:

    79170000 79196000   mscoree      (export symbols)       E:\WINDOWS\system32\mscoree.dll
      



        或者干脆没有符号

    以下为引用:

    79780000 79980000   mscorlib     (no symbols)
      



        完成以上的配置之后,就可以正式开始用WinDbg探索CLR的内部世界了,你可以敲个!SyncBlk,呵呵。

    以下为引用:

    0:005> !SyncBlk
    Index SyncBlock MonitorHeld Recursion   Thread  ThreadID     Object Waiting
    -----------------------------
    Total           3
    ComCallWrapper  0
    ComPlusWrapper  0
    ComClassFactory 0
    Free            0
      



        这不就是昨天分析的lock锁定中的那几个计数器吗 :P
    --
    .    生命的意义在于   /\   ____\ /\_ \   /\_\    http://flier_lu.blogone.net.                            .  
    .        希望         \ \  \___/_\/\ \   \/_/__     __    _ _★              .  
    .        工作          \ \   ____\\ \ \    /\  \  /'__`\ /\`'_\              .  
    .      爱你的人         \ \  \___/ \ \ \___\ \  \/\ __// \ \ \/              .  
    .     和你爱的人         \ \___\    \ \_____\ \__\ \____\ \ \_\              .  
    .        ……             \/___/     \/_____/\/__/\/____/  \/_/ @nsfocus.com.  


    ※ 来源:·BBS 水木清华站 smth.org·[FROM: 211.167.254.*]
    上一篇
    返回上一页
    回到目录
    回到页首
    下一篇


       收藏   分享  
    顶(0)
      




    ----------------------------------------------

    -----------------------------------------------

    第十二章第一节《用ROR创建面向资源的服务》
    第十二章第二节《用Restlet创建面向资源的服务》
    第三章《REST式服务有什么不同》
    InfoQ SOA首席编辑胡键评《RESTful Web Services中文版》
    [InfoQ文章]解答有关REST的十点疑惑

    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2004/11/9 2:26:00
     
     GoogleAdSense
      
      
      等级:大一新生
      文章:1
      积分:50
      门派:无门无派
      院校:未填写
      注册:2007-01-01
    给Google AdSense发送一个短消息 把Google AdSense加入好友 查看Google AdSense的个人资料 搜索Google AdSense在『 Dot NET,C#,ASP,VB 』的所有贴子 点击这里发送电邮给Google AdSense  访问Google AdSense的主页 引用回复这个贴子 回复这个贴子 查看Google AdSense的博客广告
    2024/5/1 14:49:58

    本主题贴数1,分页: [1]

    管理选项修改tag | 锁定 | 解锁 | 提升 | 删除 | 移动 | 固顶 | 总固顶 | 奖励 | 惩罚 | 发布公告
    W3C Contributing Supporter! W 3 C h i n a ( since 2003 ) 旗 下 站 点
    苏ICP备05006046号《全国人大常委会关于维护互联网安全的决定》《计算机信息网络国际联网安全保护管理办法》
    46.875ms