Linux的基本原则是没有资源应该被浪费.因此核心会使用尽可能多的RAM,来缓存来自本地和远程的文件系统的信息.系统做读写操作的时候,会将与当前运行的进程相关的数据尽量存储在RAM里.系统报告的缓存是缓冲和页缓存两者之和.缓存并不是在进程结束的时候被回收(你可能很快会启动另外一个进程,需要同样的数据),而是随需回收–比如,当你启动一个需要大量内存的进程时,Linux核心会从内存中回收缓存,将得到的内存分配给新的进程.
有些区域,比如匿名内存映射(mmps)和共享内存区域,它们被报告为缓存,但不是被核心直接释放.一般的缓存不映射到进程的地址空间,仅仅是简单的核心映射,而这些特别的缓存映射到所有挂接到它们上面的进程.
所以你执行top命令看到的
Cpu(s): 13.4% us, 6.3% sy, 0.0% ni, 79.0% id, 0.7% wa, 0.7% hi, 0.0% s
Mem: 2066800k total, 1962740k used, 104060k free, 50828k buffers
Swap: 2097136k total, 960k used, 2096176k free, 1349532k cached
PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND
6921 my_sql 15 0 131m 20m 5244 S 27 1.0 244:57.46 mysqld
18665 vhost 15 0 24980 10m 3588 S 3 0.5 0:00.34 httpd
19878 vhost 16 0 25800 11m 3584 S 3 0.6 0:00.10 httpd
19900 vhost 15 0 24884 10m 3584 S 1 0.5 0:00.03 httpd
Mem: 2066800k total, 1962740k used,并不是代表你的应用程序已经使用了1.9G的内存,这1.9G是包含了:应用程序内存 + 缓冲 + 缓存的内存的,需要用free命令查看.
下面是一个例子(单位是MB):
total used free shared buffers cached
Mem: 2018 1927 91 0 45 1293
-/+ buffers/cache: 588 1430
Swap: 2047 0 2047
在这里例子中,应用程序只使用了588MB内存,还有1430MB空闲内存可以使用.
一些简单的计算方法:
物理已用内存 = 实际已用内存 - 缓冲 - 缓存
= 1927M - 45M - 1293M
物理空闲内存 = 总物理内存 - 实际已用内存 + 缓冲 + 缓存
应用程序可用空闲内存 = 总物理内存 - 实际已用内存
应用程序已用内存 = 实际已用内存 - 缓冲 - 缓存