Linux内存分配机制

Linux内存分配机制

Scroll Down
小提示,本文编写于  2,135  天前,最后编辑于  1,712  天前,某些信息可能有些出入,仅供参考。

Linux内存分为六个部分:
total used free shared buffers cached

root@iecs:~# free -h
              total        used        free      shared  buff/cache   available
Mem:           1.9G        1.2G        188M        4.8M        564M        600M
Swap:          947M        256M        690M

我们可以看到内存 total总量为1.9G,这是笔者的服务器,一核两G

已经使用了1.2G,buff/cache 占用了564MB,

初一看就很奇怪,为什么Linux中的userd1.2G,而buff/cache这个东西怎么还占用了564MB,占用了我1/4的内存大小,度娘一波发现:

cache和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。

Buffer:缓冲区,一个用于存储速度不同步的设备或优先级不同的设备之间传输数据的区域。

通过缓冲区,可以使进程之间的相互等待变少,从而使从速度慢的设备读入数据时,速度快的设备的操作进程不发生间断。