Linux文件IO缓存总结

本文详细解析了文件IO缓存的工作原理,包括用户空间缓存与内核空间高速缓存的交互过程,以及write、read、fflush、fdatasync、fsync等系统调用如何影响数据的读写和同步。同时,介绍了stdio缓冲的不同形式和直接IO的特点。

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

文件IO缓存

用户空间缓存(堆)—IO系统调用(write等)—内核空间高速缓存—磁盘

write后立即返回,后续内核将缓存区数据写入磁盘

read从内核高速缓存中读取

设计目的:无需等待磁盘操作,减少磁盘操作

大块缓存空间,更少的系统调用,提高IO性能


stdio缓冲形式

setvbuf,setbuf,不缓冲,行缓冲,全缓冲

fflush,刷新stdio缓存->内核缓存(通过write)


同步IO数据完整性 fdatasync

读:磁盘->进程

写:数据,必要的更新文件的元数据->磁盘

同步IO文件完整性 fsync

读:磁盘->进程

写:数据,所有更新文件的元数据->磁盘


sync 更新文件信息

O_SYNC,O_DSYNC,O_RSYNC,posix_fadvise()

直接IO(绕过高速缓存):O_DIRECT,各种对齐

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值