繁体   English   中英

完整内存转储缺少堆栈信息

[英]Full Memory Dump missing stack information

我正在尝试调试客户的高CPU问题。 我试过让他们使用procdump,但是,在编写转储时挂起却没有完成。 取而代之的是,当CPU级别达到峰值时,客户使用键盘启动了完整的内存转储。

我希望能够看到所有进程线程的堆栈跟踪,但是我看不到任何一个线程的顶部4-6个堆栈帧。 令人沮丧的是,这些框架仅包含由错误检查启动的陷阱例程。 我是WinDbg的新手,所以不确定如何收集此信息。 我通过执行以下操作获取堆栈信息:

2: kd> !process 0 0 process.exe
PROCESS 8997f590  SessionId: 0  Cid: 094c    Peb: 7ffd6000  ParentCid: 01c4
DirBase: 503f1000  ObjectTable: e53f1880  HandleCount: 1924.
Image: process.exe
2: kd> !process 8997f590
PROCESS 8997f590  SessionId: 0  Cid: 094c    Peb: 7ffd6000  ParentCid: 01c4
DirBase: 503f1000  ObjectTable: e53f1880  HandleCount: 1924.
[...]
THREAD 89daf4f0  Cid 094c.0950  Teb: 7ffdf000 Win32Thread: e53f1ae0 WAIT: (Unknown) UserMode Non-Alertable
8997f8ac  NotificationEvent
[...]
ChildEBP RetAddr  
    b8cf9c04 8083d26e nt!KiSwapContext+0x26 (FPO: [Uses EBP] [0,0,4])
    b8cf9c30 8083dc5e nt!KiSwapThread+0x2e5 (FPO: [Non-Fpo])
    b8cf9c78 809208d7 nt!KeWaitForSingleObject+0x346 (FPO: [Non-Fpo])
    b8cf9ca0 8093aef7 nt!IopSynchronousServiceTail+0x180 (FPO: [Non-Fpo])
    b8cf9d38 8083387f nt!NtReadFile+0x5d5 (FPO: [Non-Fpo])
    b8cf9d38 7c82847c nt!KiFastCallEntry+0xfc (FPO: [0,0] TrapFrame @ b8cf9d64)
WARNING: Frame IP not in any known module. Following frames may be wrong.
    0012fc58 00000000 0x7c82847c
[...]

例如,如果我切换到任何线程的上下文并运行,例如kb 50我仍然只会获得前几帧。 无论如何,还有剩下的调用堆栈吗? 如果此信息已分页到磁盘,可能不可用?

此外,有关如何调试高CPU使用率的任何提示也将有所帮助。

尝试:

!process 8997f590 1f

本文介绍了您遇到的问题:

http://www.osronline.com/article.cfm?id=576

基本上,一个完整的内存转储包含许多不同的进程上下文。 为了查看用户模式状态,您需要确保调试器使用正确的进程上下文(在这种情况下,0x10标志将执行此操作)。

在调试高CPU使用率方面,!process 0 1将显示每个进程的用户和内核CPU时间。 如果出现一组特定的过程,则应从输出中清除。 但是,跟踪这种情况的更好的选择可能是xperf,它将在一段时间内对CPU进行采样(而不是像您在此处那样只是及时查看快照)。

斯科特

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM