All*_*uer 5 debugging windbg postmortem-debugging
是否可以在崩溃时创建Windows服务的完整内存转储?显然,有一些众所周知的事后调试器,可以收集失败进程的内存转储.但Windows服务的问题在于它们是在系统上下文中运行而不是在用户上下文中运行.有谁能够帮我?
到现在为止,我尝试使用WinDbg:
但它不起作用.:(
如果我编写一个普通的用户模式应用程序,它在启动后故意崩溃,WinDbg弹出并自动将.dmp文件写入目标位置.但如果我的服务崩溃,它就不会崩溃.在任务管理器中,我可以看到WinDbg在我的服务崩溃过程之后启动,但两者都只保留在列表中而没有任何转储文件.
确保AeDebug键的 Auto 设置为1。还将windbg命令行更改为:"Path\\WinDbg.exe" -p %ld \xe2\x80\x93c ".dump /ma /u D:\\CrashDump.dmp;qd" -e %ld \xe2\x80\x93G
如果您不与调试对象分离,调试器将等待进一步的命令。另外 -G 选项将在进程结束后立即关闭调试器。配置简单并且可能更适合这种情况的是sysinternals 中的procdump - 它也可以创建完整的内存转储,您可以使用以下procdump -ma -i D:\\crashdump命令安装它。
| 归档时间: |
|
| 查看次数: |
2308 次 |
| 最近记录: |