我知道的唯一相关程序是pmap,但这仅打印一个进程的内存。

我想看看物理内存是如何被占用的,以及整个物理RAM的哪个进程/库(包括内核)(与带有pmap的进程POV相对)。

理想情况下还具有图形界面。

你知道有没有这样的工具?

我知道图书馆引入的歧义。如果是这种情况,它可能会显示一条1像素宽的线和一个指向该库实际位置的箭头。

我需要什么呢?查看RAM碎片。

最佳答案

内存碎片

当Linux系统运行了一段时间后,内存碎片可能会增加,这在很大程度上取决于在其上运行的应用程序的性质。分配和释放内存的进程越多,内存越快分散。而且内核可能无法始终对所需的大小按时对足够的内存进行碎片整理。如果发生这种情况,即使有足够的可用内存,应用程序也可能无法分配更大的连续内存块。从2.6内核(即RHEL4和SLES9)开始,内存管理得到了极大的改善,内存碎片也不再是问题。

要查看内存碎片,可以使用魔术的SysRq键。只需执行以下命令:

# echo m > /proc/sysrq-trigger

此命令会将当前的内存信息转储到/var/log/messages。这是RHEL3 32位系统的示例:
Jul 23 20:19:30 localhost kernel: 0*4kB 0*8kB 0*16kB 1*32kB 0*64kB 1*128kB 1*256kB 1*512kB 1*1024kB 0*2048kB 0*4096kB = 1952kB)
Jul 23 20:19:30 localhost kernel: 1395*4kB 355*8kB 209*16kB 15*32kB 0*64kB 0*128kB 0*256kB 0*512kB 0*1024kB 0*2048kB 0*4096kB = 12244kB)
Jul 23 20:19:31 localhost kernel: 1479*4kB 673*8kB 205*16kB 73*32kB 21*64kB 847*128kB 473*256kB 92*512kB 164*1024kB 64*2048kB 28*4096kB = 708564kB)

第一行显示DMA内存碎片。第二行显示低内存碎片,第三行显示高内存碎片。输出在低内存区域显示内存碎片。但是在High Memory区域中有许多可用的大内存块,例如28 4MB。

如果未将内存信息转储到/var/log/messages,则未启用SysRq。您可以通过将sysrq设置为1来启用SysRq:
# echo 1 > /proc/sys/kernel/sysrq

从2.6内核(即RHEL4和SLES9)开始,您不需要SysRq来转储内存信息。您可以简单地检查/proc/buddyinfo的内存碎片。

这是运行2.6内核的64位服务器的输出:
# cat /proc/buddyinfo

Node 0, zone DMA 5 4 3 4 3 2 1 0 1 1 2
Node 0, zone Normal 1046 527 128 36 17 5 26 40 13 16 94
# echo m > /proc/sysrq-trigger
# grep Normal /var/log/messages | tail -1
Jul 23 21:42:26 localhost kernel: Normal: 1046*4kB 529*8kB 129*16kB 36*32kB 17*64kB 5*128kB 26*256kB 40*512kB 13*1024kB 16*2048kB 94*4096kB = 471600kB
#

在此示例中,我再次使用SysRq来显示/proc/buddyinfo中的每个数字所指的含义。

资料来源:http://www.puschitz.com/pblog/

关于linux - 如何查看Linux的RAM View 以确定碎片,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/4863707/

10-11 16:34