文件IO详解(十五)---syncfsync和fdatasync函数详解
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了文件IO详解(十五)---syncfsync和fdatasync函数详解相关的知识,希望对你有一定的参考价值。
在使用write函数向文件中写入数据的时候,并不是在调用了函数后数据就被写进了磁盘,操作系统在内核中设置了一块专门的缓冲区,数据会先被写入到内核的缓冲区中,等到缓冲区满了或者系统需要重新利用缓冲区的时候才会将此缓冲区排入到写队列中去,待到达队首的时候,将数据真正写入到磁盘当中。这就是延迟写,延迟写会造成缓冲区中的数据和磁盘中的数据之间的不同步。
=======================================================
sync函数原型:
fsync和fdatasync函数原型:
函数参数:
- fd:要操作的文件描述符
返回值:
- 调用成功返回 0
- 调用失败返回 -1
=======================================================
- sync函数会强制将内核中的所有修改过的缓冲区刷新,并立刻返回,不会等到实际的I/O操作完成后再返回。所以sync函数并不能保证数据一定写入到了磁盘中。在Linux中有一个名为update的守护进程会定期(几秒或几十秒)调用sync函数,来将刷新内核缓冲区。
- fsync函数会强制将内核中与fd文件相关的缓冲区刷新,并等待到实际I/O操作结束后再返回,如果实际I/O操作未结束,那么函数将一直处于阻塞状态。所以fsync函数可以保证数据一定被写入到磁盘中。
- fdatasync函数和fsync函数类似,唯一的区别就是fdatasync函数只会将文件的数据部分更新到磁盘中,而fsync函数不仅会将文件的数据部分还会将文件的属性更新到磁盘中。
以上是关于文件IO详解(十五)---syncfsync和fdatasync函数详解的主要内容,如果未能解决你的问题,请参考以下文章
linux 同步IO: syncfsync与fdatasync
linux 同步IO: syncfsync与fdatasync