!vm
以下是windbg.exe 内核调试器中该命令的示例输出:
*** Virtual Memory Usage ***
Physical Memory: 259676 ( 1038704 Kb)
Page File: \??\C:\pagefile.sys
Current: 1558056 Kb Free Space: 1206384 Kb
Minimum: 1558056 Kb Maximum: 3116112 Kb
Available Pages: 92541 ( 370164 Kb)
ResAvail Pages: 174950 ( 699800 Kb)
Locked IO Pages: 56 ( 224 Kb)
Free System PTEs: 187264 ( 749056 Kb)
******* 177 system cache map requests have failed ******
Free NP PTEs: 32457 ( 129828 Kb)
Free Special NP: 0 ( 0 Kb)
Modified Pages: 18154 ( 72616 Kb)
Modified PF Pages: 18154 ( 72616 Kb)
NonPagedPool Usage: 7704 ( 30816 Kb)
NonPagedPool Max: 52532 ( 210128 Kb)
PagedPool 0 Usage: 8386 ( 33544 Kb)
PagedPool 1 Usage: 8000 ( 32000 Kb)
PagedPool 2 Usage: 7980 ( 31920 Kb)
PagedPool 3 Usage: 7984 ( 31936 Kb)
PagedPool 4 Usage: 7975 ( 31900 Kb)
********** Excessive Paged Pool Usage *****
PagedPool Usage: 40325 ( 161300 Kb)
PagedPool Maximum: 40960 ( 163840 Kb)
********** 5645 pool allocations have failed **********
Session Commit: 1228 ( 4912 Kb)
Shared Commit: 6680 ( 26720 Kb)
Special Pool: 0 ( 0 Kb)
Shared Process: 4715 ( 18860 Kb)
PagedPool Commit: 40325 ( 161300 Kb)
Driver Commit: 4743 ( 18972 Kb)
Committed pages: 217663 ( 870652 Kb)
Commit limit: 624349 ( 2497396 Kb)
Total Private: 145036 ( 580144 Kb)
请注意,页面缓冲池内存几乎已全部分配,并且许多池分配都失败了。但我如何找出分配它的内容?我怀疑某处存在内存泄漏。
当达到限制时,我会得到奇怪的程序行为和到处出现的 0xC0000044 / 0xC000012D 错误。
答案1
使用Poolmon 工具找到罪魁祸首。如果是一个简单的进程,您可以在任务管理器中看到它。