unix fsync sync 数据刷新

 CPU跑linux系统接收串口发送来数据,需要将文件保存下来,接收文件完成,系统会重启,结果发现保存的文件不完整,最后的数据有丢失,利用fclose()关闭文件,而且返回正确,最后发现数据丢失与unix保存文件的策略有关系,当时习惯性的认为fclose()调用了刷新fflush(),缓冲区的数据已经保存到文件了,然而并非如此,后来在关闭文件以后,增加了延时,当延时大于一定时间,数据可以完整保存,因为unix写数据会定期刷新,延时给出时间实现将缓冲区数据保存到文件的功能。

  传统的UNIX实现在内核中设有缓冲区高速缓存或页面高速缓存,大多数磁盘I/O都通过缓冲进行。当将数据写入文件时,内核通常先将该数据复制到其中一个缓冲区中,如果该缓冲区尚未写满,则并不将其排入输出队列,而是等待其写满或者当内核需要重用该缓冲区以便存放其他磁盘块数据时,再将该缓冲排入输出队列,然后待其到达队首时,才进行实际的I/O操作。这种输出方式被称为延迟写(delayed write)(Bach [1986]3章详细讨论了缓冲区高速缓存)。延迟写减少了磁盘读写次数,但是却降低了文件内容的更新速度,使得欲写到文件中的数据在一段时间内并没有写到磁盘上。当系统发生故障时,这种延迟可能造成文件更新内容的丢失。为了保证磁盘上实际文件系统与缓冲区高速缓存中内容的一致性,UNIX系统提供了syncfsyncfdatasync三个函数。sync函数只是将所有修改过的块缓冲区排入写队列,然后就返回,它并不等待实际写磁盘操作结束。
通常称为update的系统守护进程会周期性地(一般每隔30秒)调用sync函数。这就保证了定期冲洗内核的块缓冲区。命令sync(1)也调用sync函数。
fsync函数只对由文件描述符filedes指定的单一文件起作用,并且等待写磁盘操作结束,然后返回。fsync可用于数据库这样的应用程序,这种应用程序需要确保将修改过的块立即写到磁盘上。
fdatasync函数类似于fsync,但它只影响文件的数据部分。而除数据外,fsync还会同步更新文件的属性。

 


猜你喜欢

转载自blog.csdn.net/contiune/article/details/78471200
今日推荐