博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
深度解析windows调试技术之一 [抓取user mode dump文件的几重境界]
阅读量:7223 次
发布时间:2019-06-29

本文共 1331 字,大约阅读时间需要 4 分钟。

抓取user mode dump文件的几重境界

导读
记得去年对一些朋友说过要写一些调试技术相关的文章,但是后来出于种种原因吧,还是没写成。最近终于有些时间,希望可以把这些文章补上。对于软件开发而言,调试无疑是最重要的部分之一,而对于windows 系统而言,dump文件无疑是问题发生时最全面的信息,对于一些问题而言,在对的时候抓取对的.dump文件基本上就相当于解决了一大半的问题。本文由浅入深的介绍了用户模式下抓取.dump文件的几种方式,希望对日夜奋战在加班线上的朋友有所帮助。

入门级-目标是问题发生的时候手动可以抓到dump文件

1. 当问题发生的时候使用windbg attach 到相关的进程然后使用.dump /ma 命令抓取 dump 文件。

2. 当问题发生的时候使用adplus.vbs/adplus.exe –hang 抓取相关进程的dump 文件。
入门级的方法最大的缺点就是要等到问题发生的时候才能去手动抓取.dump文件,如果问题不易重现,那么人们就不得不坐在电脑前等待问题的发生,好惨。

进阶级-目标是crash 发生的时候或者进程退出的时候可以自动抓到dump文件

1. 在问题发生的之前使用adplus.vbs/adplus.exe –crash监控相关进程的, 值得注意的是这个方法不需要手动去抓,只要crash或者进程退出,OS会自动为我们抓取dump文件,再也不用坐在显示器前等待了,来杯咖啡等着就行了。
2. 使用windbg –I 将windbg设置为即时调试器,这样当问题发生的时候,windbg就会弹出来,直到你处理了为止,同样不需要在显示器前面等待。
生活已经很美好了,但是生活可以更美好,进阶级的缺点是只能抓取crash或者进程退出的dump文件,其他情况无能为力。

高级-目标是定制在什么情况下抓取dump文件

这是最灵活的一种方式,但是也是相对最复杂的一种方式,下面为了便于说明我以一个例子来说明。

这个例子中我的目标是在notepad.exe load VERSION.dll的时候抓一个dump然后让程序继续执行。
首先在gflags的debugger中配置如下脚本:
D:\Debuggers\windbg.exe -c $$><"c:\dscript.ds"
c:\dscript.ds内容如下:
sxe ld:VERSION.dll; g; .dump /ma c:\np.dmp;g;
这个时候只要有notepad.exe开始执行,我们就会在它load VERSION.dll的时候抓取到对应的.dump 文件。
这个方法的优势是明显的,几乎任何问题都可以使用,但是它仍然有一个弊端,就是实际上进程是在调试器下运行的,对一些和性能有关的问题可能会有些影响。

总结

本文介绍的这几种方式由浅入深,各有利弊,对于大部分的调试情况已经足够了,希望对大家有所帮助,当然除了本文介绍的方式,大家还可以选择其他一些工具来抓取dump文件,此处不一一列举,另外对于kernel dump 文件的抓取,由于日常的应用开发用的不多,故本文暂不作介绍,如果感兴趣的朋友多,我再写一篇专门抓取内核dump的文章。

转载地址:http://quzfm.baihongyu.com/

你可能感兴趣的文章
我的友情链接
查看>>
dojo框架用hitch实现函数与上下文的绑定
查看>>
ubuntu编译安装vim7.4
查看>>
python之利用PIL库实现页面的图片验证码及缩略图
查看>>
IP-COM设置×××
查看>>
VPC配置案例
查看>>
十年IT运维谈(五):要专业化还是平台化?
查看>>
分享超级给力的一个外发光Shader
查看>>
oblog_4.6_SQL 语句
查看>>
通过Git WebHooks+脚本实现自动更新发布代码之shell脚本
查看>>
对象实例化、字符串的使用方法
查看>>
keepalived基于LVS实现高可用,实现web服务的高可用
查看>>
80端口被Microsoft-HTTPAPI/2.0占用的解决办法
查看>>
无法抗拒Minecraft给予超高的自由度和探索-微访谈
查看>>
数据结构之串
查看>>
我的友情链接
查看>>
lvs+keepalived+nginx+tomcat高可用高性能集群部署
查看>>
实验:搭建主DNS服务器
查看>>
org.gjt.mm.mysql.Driver与com.mysql.jdbc.Driver区别
查看>>
部署exchange2010三合一:之五:功能测试
查看>>