深度解析windows调试技术之一 [抓取user mode dump文件的几重境界]
抓取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的文章。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 【自荐】一款简洁、开源的在线白板工具 Drawnix