Linux 内存中Page cache和buffer cache 的区别

Page Cache和Buffer Cache是Linux内存管理中的两个重要概念,常常引起混淆。Page Cache主要缓存文件数据,而Buffer Cache则用于缓存磁盘数据,如元数据。在文件系统层次,Page Cache服务于文件的业务数据,Buffer Cache服务于直接对磁盘操作的数据。两者在处理上保持一致,但针对的对象不同,Page Cache针对文件,Buffer Cache针对磁盘块。

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

linux page buffer cache深入理解



Page cache和buffer cache一直以来是两个比较容易混淆的概念,在网上也有很多人在争辩和猜想这两个cache到底有什么区别,讨论到最后也一直没有一个统一和正确的结论,在我工作的这一段时间,page cache和buffer cache的概念曾经困扰过我,但是仔细分析一下,这两个概念实际上非常的清晰。如果能够了解到这两个cache的本质,那么我们在分析io问题的时候可能会更加得心应手。


Page cache实际上是针对文件系统的,是文件的缓存,在文件层面上的数据(在文件系统构架里,组成一个文件的有两部分:文件的元数据,即FCB,还有文件的业务数据,即比如平时我们用记事本程序打开一个文件所看到的数据。“在文件层面上的数据”指的就是文件的业务数据会缓存到page cache(即page cache规划就是用来缓存来自在文件系统下的任一文件的业务数据所存放的那些扇区))。文件的逻辑层需要映射到实际的物理磁盘,这种映射关系由文件系统来完成。当page cache的数据需要刷新时,page cache中的数据交给buffer cache,但是这种处理在2.6版本的内核之后就变的很简单了,没有真正意义上的cache操作(是说直接将文件的业务数据(以扇区为读写的基本单位方式,这个方式也是数据从磁盘读取到buffer cache上的方式)读取到page cache上,不经过buffer cache?)。


Buffer cache是针对磁盘块(即扇区)的缓存(即buffer cache允许缓存的数据可以是来自一个磁盘上任意一个扇区的数据),也就是在没有文件系统的情况下(准确的表达是,无论有否文件系统的存在,设备驱动程序读取的数据(也即直接对磁盘进行操作的数据)都是缓存到buffer cache中),直接对磁盘进行操作的数据会缓存到buffer cache中,例如,文件系统的元数据都会缓存到buffer cache中。

也就是说,首先我们要知道进程(0)(即设备驱动程序,或设备文件)对磁盘进行读写的基本单位是扇区(不是其他大小,如文件系统块大小),所以内存上(的是无论page cache,还是buffer cache)对磁盘进行读写的基本单位是扇区。进程(1)对Buffer cac

Linux内核中,Page CacheBuffer Cache都是用于缓存文件系统数据的机制,但它们的缓存对象缓存方式不同。 Page Cache是用于缓存文件系统数据块的机制,它缓存的是文件系统中的整个页(通常为4KB)。当应用程序请求访问文件时,内核会首先在Page Cache中查找对应的页,如果找到了就直接返回给应用程序,避免了访问磁盘的开销。如果Page Cache中没有找到对应的页,则内核会从磁盘中读取相应的数据块,并将其缓存到Page Cache中。Page Cache的优点是能够加速对文件的访问速度,提高系统的性能。但是,它也会占用系统的内存资源,如果文件系统中的文件过多,Page Cache可能会占用大量的内存资源。 Buffer Cache是用于缓存块设备数据块的机制,它缓存的是块设备中的数据块(通常为512字节或4KB)。当应用程序请求访问块设备时,内核会首先在Buffer Cache中查找对应的数据块,如果找到了就直接返回给应用程序,避免了访问块设备的开销。如果Buffer Cache中没有找到对应的数据块,则内核会从块设备中读取相应的数据块,并将其缓存到Buffer Cache中。Buffer Cache的优点是能够加速对块设备的访问速度,提高系统的性能。但是,它也会占用系统的内存资源,如果块设备中的数据块过多,Buffer Cache可能会占用大量的内存资源。 因此,Page CacheBuffer Cache都是用于加速对文件系统或块设备的访问速度的机制,它们的区别在于缓存的对象缓存的方式不同。Page Cache缓存的是文件系统的整个页,Buffer Cache缓存的是块设备的数据块。Page Cache的缓存方式是基于文件系统的,Buffer Cache的缓存方式是基于块设备的。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值