我在 CentOS 服务器上运行了繁重的应用程序,并且看到了奇怪的内存行为。这是一个 munin 图的快照:
如您所见,提交的内存量逐渐增加,导致交换文件被使用。让我感到奇怪的是,非活动内存的数量也在不断增长。据我了解,非活动内存实际上是内存已释放但尚未被操作系统清理并放回空闲内存池中。似乎内存不足是由于缺乏清理造成的,但我可能错了。
你能提供一些提示来找出问题的原因和/或让 CentOS 回收非活动内存吗?
谢谢。
一些额外的信息:
1)我在 /tmp 上安装了一个 tmpfs,并且存储在那里的文件数量增加了(但它是非活动内存量的两倍)。
2) cat /proc/meminfo (在图像之后的阶段)给出:
MemTotal: 14371428 kB
MemFree: 1207108 kB
Buffers: 35440 kB
Cached: 4276628 kB
SwapCached: 785316 kB
Active: 9038924 kB
Inactive: 3902876 kB
HighTotal: 0 kB
HighFree: 0 kB
LowTotal: 14371428 kB
LowFree: 1207108 kB
SwapTotal: 10223608 kB
SwapFree: 6438320 kB
Dirty: 627792 kB
Writeback: 0 kB
AnonPages: 7844560 kB
Mapped: 49304 kB
Slab: 146676 kB
PageTables: 27480 kB
NFS_Unstable: 0 kB
Bounce: 0 kB
CommitLimit: 17409320 kB
Committed_AS: 16471488 kB
VmallocTotal: 34359738367 kB
VmallocUsed: 275852 kB
VmallocChunk: 34359462007 kB
HugePages_Total: 0
HugePages_Free: 0
HugePages_Rsvd: 0
Hugepagesize: 2048 kB
3) 该应用程序是 MySQL、Heritrix ( http://crawler.archive.org/ ) 和基于 Tomcat 的 Java servlet 的组合来管理事物。
这是错误的。“非活动”内存是一段时间内未被任何应用程序使用的主动映射内存。当需要交换时,内存会从这样标记的页面中取出并换出。它也可以用于换出页面缓存。
这两者不一定相关,但对我来说,这强烈地看起来好像有什么东西正在泄漏内存。您的页面没有被任何应用程序访问的事实正在增长,并且交换也在增长,这表明某些事情正在分配内存,然后忘记它然后不释放它。
内存可能是“非活动的”,例如,如果 malloc() 被调用。这是一个 libc 调用,它可能会分配一块内存,但实际上只有一部分用于执行任何工作(无论如何都少于分配的页数)。即使你在 malloc 中释放它实际上并不意味着你通过要求操作系统这样做来释放内存,它只是 mallocs 表可能标记为“可重用”,它可能会在之后释放它。
这个应用程序是什么,它有内存泄漏吗?即,如果您的应用程序终止,内存是否会返回给操作系统?
如果您的应用程序正在泄漏内存,您需要使用诸如电子围栏之类的东西来发现这些问题并纠正它们。
你的应用程序是用什么写的?您需要使用正确的调试器来编写它的语言。
我非常怀疑操作系统正在泄漏内存,除非您的应用程序正在使用大量资源并且没有正确释放它们。
此外,你的记忆图非常非常繁忙,很难理解,那里有大约 20 种颜色,几乎像泥巴一样清晰。
您认为这是您的ram磁盘的问题吗?它可能会扩大以满足需求,但不会在需要时缩减规模。