Linux内存buffer和cache的区别

本文深入解析Linux系统中内存的buffer和cache的区别与使用方式,包括它们如何分配、如何影响系统性能以及如何查看相关统计数据。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Linux内存buffer和cache的区别
2011-10-07       0  个评论      
收藏     我要投稿

 

内存使用说明

Free 命令相对于top 提供了更简洁的查看系统内存使用情况

 

 

[root@rac1 ~]# free

 

 

total used free shared buffers cached

 

 

Mem: 1035108100898426124 0 124212 413000

 

 

-/+ buffers/cache: 471772 563336

 

 

Swap: 2096472 842320 1254152

 

 

这里显示的单位是KB。

 

 

在linux的内存分配机制中,优先使用物理内存,当物理内存还有空闲时(还够用),不会释放其占用内存,就算占用内存的程序已经被关闭了,该程序所占用的内存用来做缓存使用,对于开启过的程序、或是读取刚存取过得数据会比较快。有关Linux内存机制参考:

 

 

Linux 内存机制

 

 

Mem:表示物理内存统计。
-/+ buffers/cached:表示物理内存的缓存统计
Swap:表示硬盘上交换分区的使用情况。只有mem被当前进程实际占用完,即没有了buffers和cache时,才会使用到swap。

 

 

Mem 行(第一行)数据说明:

 

 

Total:1035108KB。表示物理内存总大小。

 

 

Used:1008984KB。表示总计分配给缓存(包含buffers 与cache )使用的数量,但其中可能部分缓存并未实际使用。

 

 

Free:26124KB。表示未被分配的内存。

 

 

Shared:0kb。共享内存,一般系统不会用到。

 

 

Buffers:124212KB。系统分配但未被使用的buffers 数量。

 

 

Cached:413000KB。系统分配但未被使用的cache 数量。

 

 

-/+ buffers/cache 行(第二行)数据说明:

 

 

Used:471772kb,实际使用的buffers 与cache 总量,也是实际使用的内存总量。

 

 

Free: 563336kb, 未被使用的buffers 与cache 和未被分配的内存之和,这就是系统当前实际可用内存。

 

 

根据以上分析,可以得出一下结论:

 

 

1. 实际可用内存大小:

 

 

Free(-/+ buffers/cache行)= Free(Mem)+buffers(Mem)+Cached(Mem);

 

 

563336 = 26124 + 124212+ 413000

 

 

2. 已经分配的内存大小:

 

 

Used(Mem) = Used(-/+ buffers/cache)+ buffers(Mem) + Cached(Mem)

 

 

1008984kb = 471772 + 124212 +413000

 

 

3. 物理内存总大小

 

 

total(Mem)= used(-/+ buffers/cache) + free(-/+ buffers/cache)

 

 

1035108 = 471772 + 563336

 

 

二. 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.

 

 

2.1 Cache

 

 

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。

 

2.2 Buffer

 

 

Buffer:缓冲区,一个用于存储速度不同步的设备或优先级不同的设备之间传输数据的区域。通过缓冲区,可以使进程之间的相互等待变少,从而使从速度慢的设备读入数据时,速度快的设备的操作进程不发生间断。

 

 

在Free命令中显示的buffer和cache,它们都是占用内存:

 

 

buffer : 作为buffer cache的内存,是块设备的读写缓冲区,更靠近存储设备,或者直接就是disk的缓冲区。

 

 

cache: 作为page cache的内存, 文件系统的cache,是memory的缓冲区

 

 

如果cache 的值很大,说明cache住的文件数很多。如果频繁访问到的文件都能被cache住,那么磁盘的读IO 必会非常小

Linux内存buffer/cache很大是因为Linux系统采用了一种称为页缓存(Page Cache)的机制来提高文件系统的性能。具体来说,当文件被读取到内存中时,Linux会将读取到的文件数据缓存到内存的页缓存中,以便下次访问相同文件时可以直接从页缓存中获取,而不需要再次从磁盘中读取。这种机制可以大大提升系统IO的性能。 Linux内存buffer/cache的大小受到系统资源管理的影响,它会充分利用可用的内存空间来提供更高效的文件访问。当系统运行时,如果有大量的可用内存,并且没有其他进程需要使用,Linux会将这些多余的内存用于buffer/cache。这样一来,当需要从磁盘读取文件时,大部分情况下可以直接从内存中获取,而不必再次访问磁盘,从而大大提高系统的响应速度。 值得注意的是,虽然buffer/cache占用了大量内存,但这些内存并不是完全被占用,而是可以根据需要被释放的。当其他程序需要更多的内存时,Linux会自动将buffer/cache中的数据释放出来,以满足其他程序的需求。这个过程被称为自动缓存(Automatic caching),可以确保系统内存始终处于最佳状态。 总而言之,Linux内存buffer/cache很大是Linux系统为了提高文件系统的性能而采取的一种机制。通过将文件数据缓存到内存中,可以减少对磁盘的读取操作,从而大大提升了系统的响应速度。同时,这些内存可以根据需要进行释放,确保系统内存始终处于最佳状态。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值