Linux free命令查看内存情况学习小记

Share on:

最近项目碰到php-fpm占用太多内存的情况,为了深入了解其原因,开始学习os相关的内存知识,记录备忘下

1              total       used       free     shared    buffers     cached
2 Mem:      24677460   23276064    1401396          0     870540   12084008
3 -/+ buffers/cache:   10321516   14355944
4 Swap:     25151484     224188   24927296

第二行(mem),从OS的角度来看,因为对于OS,buffers/cached 都是属于被使用,所以他的可用内存是1401396KB,已用内存是24677460KB,其中包括,内核(OS)使用+Application(X,oracle,etc)使用的+buffers+cached。

total:总计物理内存的大小。

used:已使用多大。

free:可用有多少。

Shared:多个进程共享的内存总额,现在已经deprecated,其值总是0(当然在一些系统上也可能不是0,主要取决于free命令是怎么实现的)。

Buffers/cached:磁盘缓存的大小,FO[2][5]表示被OS buffer住的内存。FO[2][6]表示被OS cache的内存。在有些时候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.

也就是说buffer是用于存放要输出到disk(块设备)的数据的,而cache是存放从disk上读出的数据。这二者是为了提高IO性能的,并由OS管理。

第三行(-/+ buffers/cached),从应用程序角度来看,对于应用程序来说,buffers/cached 是等于可用的,因为buffer/cached是为了提高文件读取的性能,当应用程序需在用到内存的时候,buffer/cached会很快地被回收。

used:表示一个应用程序认为系统被用掉多少内存。

free:表示一个应用程序认为系统还有多少内存。

因为被系统cache和buffer占用的内存可以被快速回收,所以通常FO[3][3]比FO[2][3]会大很多。

这里还用两个等式:

  • FO[3][2] = FO[2][2] – FO[2][5] – FO[2][6]
  • FO[3][3] = FO[2][3] + FO[2][5] + FO[2][6]

第四行,Swap当系统的物理内存不够用的时候,就需要将物理内存中的一部分空间释放出来,以供当前运行的程序使用。那些被释放的空间可能来自一些很长时间没有什么操作的程序,这些被释放的空间被临时保存到Swap空间中,等到那些程序要运行时,再从Swap中恢复保存的数据到内存中。这样,系统总是在物理内存不够时,才进行Swap交换。

<p>
  如何看额定值(RHEL4.0):
</p>

<p>
  #cat /proc/meminfo
</p>

<p>
  交换将通过三个途径来减少系统中使用的物理页面的个数:
</p>

<p>
  1.减少缓冲与页面cache的大小,
</p>

<p>
  2.将系统V类型的内存页面交换出去,
</p>

<p>
  3.换出或者丢弃页面。(Application 占用的内存页,也就是物理内存不足)。
</p>

<p>
  事实上,少量地使用swap是不会影响到系统性能的。
</p>

还有free命令的所有输出值都是从/proc/meminfo中读出的。

闽ICP备12003472号-7