一,利用free命令监控内存

从操作系统角度和应用程序角度进行分析free命令结果。
Linux系统下对内存的调度有缓存机制,如果系统需求内存很大的话,被缓存的内存页是可以回收的。
不过一般为了高效,是处于cache状态。
如果你用free命令查看内存使用状况,-/+ buffers/cache这行的数值才是你需要获取的信息。

 [root@backup ~]# free -m

             total       used       free     shared    buffers     cached

Mem:          7974       7890         84          0        152       5730

-/+ buffers/cache:       2006       5968

Swap:         8173          0       8173

1、操作系统是看 Mem
这里的free=84才是真正没有任何数据的(注意,不是系统的可用内存量),不涉及到Linux高效数据存取(Access)中提到的缓存。
total:内存总数
used:已使用内存数
free:空闲的内存数
shared:可以忽略,过时不用的了,总是为0
buffers:Buffer缓存内存数
cached:Page缓存内存数
关系:total=used+free

2、应用程序看-/+ buffers/cache(这行代表的就是程序真正使用内存量和剩余内存量):
这里的free(106)表示可以被应用程序可支配的剩余内存,也就是系统还有多少内存可以被apache这类程序使用
used=Mem行中的used – buffers – cached
free=Mem行中的free + buffers + cached
可见-buffers/cache反映的是被程序实实在在吃掉的内存,而+buffers/cache反映的是可以挪用的内存总数。
当可用内存少于额定值的时候,就会开会进行交换。

3、Swap
只要不用swap的交换空间,就不用担心自己的内存太少。如果常常swap用很多,可能你就要考虑加物理内存了。这也是linux看内存是否够用的标准。

其实可以从二个方面来解释:
对操作系统来讲是Mem的参数.buffers/cached 都是属于被使用的。
对应用程序来讲是(-/+ buffers/cach),buffers/cached 是等同可用的,因为buffer/cached是为了提高程序执行的性能,当程序使用内存时,buffer/cached会很快地被使用。

所以,以应用来看看,以(-/+ buffers/cache)的free和used为主.所以我们看这个就好了。另外告诉大家一些常识。Linux为了提高磁盘和内存存取效率。
Linux做了很多精心的设计, 除了对dentry进行缓存(用于VFS,加速文件路径名到inode的转换), 还采取了两种主要Cache方式:Buffer Cache和Page Cache。
前者针对磁盘块的读写,后者针对文件inode的读写。这些Cache能有效缩短了 I/O系统调用(比如read,write,getdents)的时间。

一般有这样一个经验公式:应用程序可用内存/系统物理内存>70%时,表示系统内存资源非常充足,不影响系统性能,
应用程序可用内存/系统物理内存<20%时,表示系统内存资源紧缺,需要增加系统内存,
20%<应用程序可用内存/系统物理内存<70%时,表示系统内存资源基本能满足应用需求,暂时不影响系统性能。

二,利用vmstat命令监控内存

 [root@backup ~]# vmstat 2 10

procs -----------memory---------- ---swap-- -----io---- --system-- -----cpu------

 r  b   swpd   free   buff  cache   si   so    bi    bo   in   cs us sy id wa st

 0  3    192  92896 155768 5863332    0    0   283   338    0    0  5  1 78 16  0

 0  3    192  93456 155792 5863420    0    0    44   906 1220  545  0  1 75 24  0

 0  0    192  93016 155796 5863488    0    0    26    82 1138  889  1  1 80 17  0

 0  0    192  92956 155808 5863548    0    0    12   132 1116 1231  1  0 98  1  0

 0  2    192  86012 155824 5863604    0    0    12   708 1252  943  2  2 73 23  0

 0  0    192  85952 155832 5863660    0    0    46    70 1146  483  2  1 77 20  0

 0  2    192  91964 155852 5863772    0    0    20   934 1286  749  1  1 85 13  0

 0  1    192  91852 155868 5864072    0    0    70   214 1178  530  0  1 75 24  0

 0  0    192  91548 155884 5864040    0    0    78    32 1102  537  0  1 95  5  0

 0  3    192  91804 155888 5864180    0    0    10   782 1208  597  0  1 76 23  0

1、看memory列
swpd: 虚拟内存使用情况,单位:KB.如果不为0,或者比较大,但si,so一直为0,这种情况通常也不会影响系统性能。
free: 当前系统空闲的内存,单位KB
buff:表示buffers cache的内存数量,一般对块设备的读写才需要缓冲。
cache:表示page cached的内存数量,一般作为文件系统cached,频繁访问的文件都会被cached,
如果cache值较大,说明cached的文件数较多,如果此时IO中bi比较小,说明文件系统效率比较好。

2、看swap列
si:表示从磁盘交换到内存的交换页数量,单位:KB/秒
so:表示从内存交换到磁盘的交换页数量,单位:KB/秒
一般情况下,si、so的值都为0,如果si、so的值长期不为0,则表示系统内存不足。需要考虑增加系统内存。