我有一个相对较小的家用 Red Hat Linux 服务器(大约 8 GB RAM)。除了运行一些本地开发的应用程序来跟踪各种事情之外,我不会使用它。在盒子上运行的唯一真实的东西是一个数据库和一个网络服务器。
我注意到,当使用 NMON 和 TOP 等工具检查系统计数器时,总系统可用内存相对较低(大约几百 MB),而数据库和 Web 服务器的活动内存仍然很低(仅共消耗 3 GB)。即使包括所有其他正在运行的进程,总消耗的内存也小于 4 GB。
为什么 Red Hat Linux 报告的可用内存少于总内存减去正在运行的进程已用内存的总和?
不要将空闲内存与未使用内存混淆。空闲内存,在 unix 世界中是一页物理内存,没有映射到它的逻辑数据。未使用的内存确实有一些数据映射到它,但它当前没有被正在运行的进程主动使用。
Linux(和所有 Unix 操作系统)尽量减少可用内存。相反,它们使用未主动映射到正在运行的操作系统中的进程的内存,用于文件缓存和各种 IO 传输操作的缓冲区。
其他可能让您感到困惑的事情是您不能简单地将所有正在运行的进程正在使用的内存相加来获得总内存在使用中的数字。如果您尝试这样做,您会很快发现您的应用程序使用的内存似乎比机器上实际存在的内存要多。这有两个原因
最近在lwn.net 上有一篇文章讨论了这个问题。
Linux 将主动将文件系统访问缓存到内存中,以提供更快的磁盘访问时间。这没什么好担心的。
在盒子上运行 free -m 会让您更好地了解内存的使用位置。
下面是从我的一个盒子中提取的输出。可用内存为 147Meg,几乎 4G 缓存用于文件系统访问请求。
您是否还包括“缓冲”和“缓存”字段?
对于 linux,查看 /proc/meminfo 中的 Committed_AS,这是内核实际承诺运行进程的内存量(实际 + 交换)。
Linux 非常有效地使用内存,任何未向某些进程承诺的块都用于缓存最近/经常访问的文件。因此,Linux 通常会在启动后不久使用 90% 的所有可用物理内存。
查看内核承诺提供 .. 和脏(交换)使用的内容,这可以为您提供更好的整体情况。
如果您需要调整此行为,请更新您的问题:)
这是 Linux 的标准 MO。一些发行版通过 sysctl 调整内存管理以满足他们的需求。但是,您报告的内容非常典型。
你在系统上运行什么样的内核?除非在启用 PAE 的情况下编译,否则 32 位内核只会报告大约 3.6GB 的内存。
话虽如此,如果这是现代版本的 Redhat Enterprise Linux(或 CentOS) - v3 及更高版本 - 默认的 32 位内核将启用此功能。
如果您可以发布上面详述的“免费”命令的输出,我们将能够查看这是否是问题所在。