什么会导致非活动内存增加以及如何回收它?

Boa*_*oaz 6 linux memory centos tmpfs

我在 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
Run Code Online (Sandbox Code Playgroud)

3) 该应用程序结合了 MySQL、Heritrix ( http://crawler.archive.org/ ) 和一个基于 Tomcat 的 Java servlet 来管理事物。

Mat*_*Ife 5

我的理解是,非活动内存实际上是操作系统已释放但尚未清理并放回空闲内存池中的内存。

这是错误的。“非活动”内存是有一段时间没有被任何应用程序使用的主动映射内存。当需要交换时,内存会从这样标记的页面中取出并换出。它也可用于换出页面缓存。

正如您所看到的,提交的内存量逐渐增加,导致交换文件被使用。让我感到奇怪的是,非活动内存的数量也在不断增长。

这两者不一定相关,但对我来说,这看起来好像有什么东西正在泄漏内存。您的页面没有被任何增长的应用程序访问,并且交换增长也表明某些事情正在分配内存,忘记它然后没有释放它。

内存可能处于“非活动状态”,例如调用 malloc() 时。这是一个 libc 调用,它可能会分配一块内存,但实际上只有其中的一部分用于执行任何工作(无论如何都少于分配的页面数)。即使您在 malloc 中释放它实际上并不意味着您通过要求操作系统这样做来释放内存,它只是 mallocs 表可能标记为“可重用”,它可能会在之后释放它。


The*_*tor 0

这是什么应用程序,它是否存在内存泄漏?即,如果您的应用程序终止,内存是否会返回给操作系统?

如果您的应用程序正在泄漏内存,您需要使用诸如电子围栏之类的工具来查找这些问题并纠正它们。

你的申请是用什么写的?您需要针对其编写的语言使用正确的调试器。

我非常怀疑操作系统正在泄漏内存,除非您的应用程序使用了大量资源并且没有正确释放它们。

另外,你的记忆图非常非常繁杂,非常难以理解,那里有大约 20 种颜色,它像泥一样清晰。

你认为你的内存盘有问题吗?它可能会扩大规模以满足需求,但不会在需要时缩减规模。