在RedHat Linux 6.2上,我正在运行free -m
,它显示几乎所有使用的8GB
total used free shared buffers cached
Mem: 7989 7734 254 0 28 7128
-/+ buffers/cache: 578 7411
Swap: 4150 0 4150
但同时在top -M
我看不到任何使用所有内存的进程:
top - 16:03:34 up 4:10, 2 users, load average: 0.08, 0.04, 0.01
Tasks: 169 total, 1 running, 163 sleeping, 5 stopped, 0 zombie
Cpu(s): 0.7%us, 0.3%sy, 0.0%ni, 98.6%id, 0.4%wa, 0.0%hi, 0.0%si, 0.0%st
Mem: 7989.539M total, 7721.570M used, 267.969M free, 28.633M buffers
Swap: 4150.992M total, 0.000k used, 4150.992M free, 7115.312M cached
PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND
1863 sroot 20 0 398m 24m 9.8m S 0.3 0.3 3:12.87 App1
1 sroot 20 0 2864 1392 1180 S 0.0 0.0 0:00.91 init
2 sroot 20 0 0 0 0 S 0.0 0.0 0:00.00 kthreadd
3 sroot RT 0 0 0 0 S 0.0 0.0 0:00.07 migration/0
4 sroot 20 0 0 0 0 S 0.0 0.0 0:00.00 ksoftirqd/0
5 sroot RT 0 0 0 0 S 0.0 0.0 0:00.00 migration/0
6 sroot RT 0 0 0 0 S 0.0 0.0 0:00.00 watchdog/0
7 sroot RT 0 0 0 0 S 0.0 0.0 0:00.08 migration/1
8 sroot RT 0 0 0 0 S 0.0 0.0 0:00.00 migration/1
我也尝试了这个ps mem script但是它显示了大约400MB内存的使用。
答案 0 :(得分:109)
不要看“Mem”行,看看下面的那行。
Linux内核消耗尽可能多的内存来提供I / O缓存(以及其他非关键缓冲区,但缓存将是这种用法的大部分)。当它们请求时,该存储器被放弃到进程。 “ - / + buffers / cache”行显示了I / O缓存占用后的调整值,即进程使用的内存量和进程可用的数量(在这种情况下,使用了578MB和7411MB免费)。
“Mem”和“ - / + buffers / cache”行之间的已用内存差异显示内核为缓存目的使用了多少:7734MB - 578MB = 7156MB I / O缓存。如果进程需要这个内存,内核将简单地缩小I / O缓存的大小。
答案 1 :(得分:14)
另外,如第一行所示
total used free shared buffers cached
Mem: 7989 7734 254 0 28 7128
-/+ buffers/cache: 578 7411
如果我们添加(缓存[7128] + buffers [28] + free [254]),我们将得到大约第二行的自由[7411]值
7128 + 28 + 254 = 7410
答案 2 :(得分:0)
如果缓存很小,请尝试以下命令:
ps aux --sort -rss