Linux下Free命令以及Cached和Buffers的区别

  在介绍Cached与Buffers区别之前,我们先来看看Linux下的内存信息。

  

  首先我们来看看上述都表示什么意思:

  Mem:表示物理内存统计 
  -/+ buffers/cached:表示物理内存的缓存统计 
  Swap:表示硬盘上交换分区的使用情况,这里我们不去关心。
  系统的总物理内存:255988Kb(256M),但系统当前真正可用的内存并不是第一行free 标记的 24284Kb,它仅代表未被分配的内存。

  我们使用total1、used1、free1、used2、free2 等名称来代表上面统计数据的各值,1、2 分别代表第一行和第二行的数据。

  total1:表示物理内存总量。 
  used1:表示总计分配给缓存(包含buffers 与cache )使用的数量,但其中可能部分缓存并未实际使用。 
  free1:未被分配的内存。 
  shared1:共享内存,一般系统不会用到,这里也不讨论。 
  buffers1:系统分配但未被使用的buffers 数量。 
  cached1:系统分配但未被使用的cache 数量。buffer 与cache 的区别见后面。 
  used2:实际使用的buffers 与cache 总量,也是实际使用的内存总量。 
  free2:未被使用的buffers 与cache 和未被分配的内存之和,这就是系统当前实际可用内存。

  可以整理出如下等式:

    total1 = used1 + free1

    total1 = used2 + free2

    used1 = buffers1 + cached1 + used2

    free2 = buffers1 + cached1 + free1

    内存利用率 = used2 / total1

  buffer 与cache 的区别

      A buffer is something that has yet to be "written" to disk.

 

         A cache is something that has been "read" from the disk and stored for later use.

     两者都是RAM中的数据。简单来说,buffer是即将要被写入磁盘的,cache是被从磁盘中读出来的。buffer是由各种进程分配的,被用在如输入队列等方面,一个简单的例子如某个进程要求有多个字段读入,在所有字段被读入完整之前,进程把先前读入的字段放在buffer中保存。cache经常被用在磁盘的I/O请求上,如果有多个进程都要访问某个文件,于是该文件便被做成cache以方便下次被访问,这样可提供系统性能。

    需要注意的是,free表示的是当前完全没有被程序使用的内存;而cache在有需要时,是可以被释放出来以供其它进程使用的(当然,并不是所有cache都可以释放,比如当前被用作ramfs的内存)。而available才真正表明系统目前可以提供给应用程序使用的内存。/proc/meminfo3.14内核版本开始提供MemAvailable的值;在2.6.27~3.14版本之间,是free程序自己计算available的值;早于2.6.27版本,available的值则同free一样。

 

posted @ 2017-05-26 15:16  看雪。  阅读(703)  评论(0编辑  收藏  举报