由来:最近zabbix监控发现服务器主机发生内存告警通知,同时内存使用率越来越高甚至超过90%使用率,这个不得不引起运维人员高度注意。

经过核查原来主要是cached作怪,我们可以通过free -m得出以下:


total : 物理内存的总大小
used :已经使用内存大小
shared:共享的内存大小
buffers:缓冲区内存:(磁盘块的读写频繁,linux内存机制做缓冲池)
cached:高速缓存

  • cached和 buffer的区别:

Buffer:缓冲区,一个用于存储速度不同步的设备或优先级不同的设备之间传输数据的区域。通过缓冲区,可以使进程之间的相互等待变少,从而使从速度慢的设备读入数据时,速度快的设备的操作进程不发生间断。
Cache:高速缓存,是位于CPU与主内存间的一种容量较小但速度很高的存储器。由于CPU的速度远高于主内存,CPU直接从内存中存取数据要等待一定时间周期,Cache中保存着CPU刚用过或循环使用的一部分数据,当CPU再次使用该部分数据时可从Cache中直接调用,这样就减少了CPU的等待时间,提高了系统的效率。Cache又分为一级Cache(L1 Cache)和二级Cache(L2 Cache),L1 Cache集成在CPU内部,L2 Cache早期一般是焊在主板上,现在也都集成在CPU内部,常见的容量有256KB或512KB L2 Cache。
Cache的工作原理图如下:

  • 以下是清理cache

cat /proc/sys/vm/drop_caches 默认是0,参照如下图吗,可以根据自己需求清理。

使用前最好首先执行sync命令
sync - 强制将内存中的文件缓冲内容写到磁盘

更改后监控得出以下:


Comments

2015-10-25