执行free -mh 命令,可以看到如下显示:
总内存15G,显示使用了14G,剩余只有466M。这是因为Linux自动管理了Cache造成的。
特别注意下第二行,这是什么意思呢?解释如下
-buffers/cache = used - buffers - cached,这个是应用程序真实使用的内存大小
+buffers/cache = free + buffers + cached,这个是服务器真实还可利用的内存大小
就是说,buffers+cache=10.7G,被使用的内存中实际应用程序占用了14-10.7=3.3G,总的可用内存为466M+10.7G=11G。
可用使用如下命令清除cache:
sync
echo 3 > /proc/sys/vm/drop_caches
清理之后如下所示,cache从10.7G减少到6.8G(由于执行命令时正在进行io操作,cache又不停增加了)
实际上cache区域内存是自动管理的,当内存不够时操作系统会自动回收cache内存,不需要手动清除=.=
结论:如果想知道程序占用了多少内存,实际上只需要看第二行就可以了。
各参数含义:
total:总物理内存
used:已使用内存
free:完全未被使用的内存
shared:应用程序共享内存
buffers:缓存,主要用于目录方面,inode值等
cached:缓存,用于已打开的文件
-buffers/cache:应用程序使用的内存大小,used减去缓存值
+buffers/cache:所有可供应用程序使用的内存大小,free加上缓存值