首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

linux 同步IO: sync、fsync与fdatasync

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

03

M2O视频存储空间调整记录

之前M2O流媒体平台的视频点播存储空间将近满了。为了避免硬盘满了,造成视频录制异常。进行了视频存储资源的迁移。 实际执行的时候,大概1分钟内完成新旧平台的切换。但是前期准备工作进行了很久。回想起来之前学校的媒资管理系统更换硬盘的情况,和这个有很多类似。之所以耗费时间,主要是原有存储设备向新的存储设备的数据拷贝、文件数量校对、文件大小校对上。 这个调整,从开始筹划,到最终完成,大概有下面几个阶段: 1)前期和开发公司运维人员讨论出来一种解决方案,利用硬盘挂载、网络共享的方法实现存储设备的调整 2)不同服务器之间硬盘的挂载 3)制定了迁移时候的方案 4)拷贝数据,前后持续了2周左右。当中涉及到了视频截图文件夹中存在500G左右的直播截图文件的确认和清理工作(最终证明视频截图和计划任务的配置有关,相关功能已停用,但原有截图没有自动清除) 5)核心部分,告诉所有后台编辑人员停止视频上传、挑选了没有视频录制、没有视频时移也没有转码进程的时间,进行了存储设备调整 6)调整完后,测试了自动收录和时移功能,发现转码设备获取视频路径存在异常,导致转码服务无法获取到原始视频。调整新的资源位置后,重新提交转码任务,顺利完成视频转码 7)配置了几台设备的开机硬盘自动挂载,这样就可以一定程度避免设备重启导致的无法获取资源问题 用到和加深理解的几个命令有 1)查看文件夹以及子文件件的文件数量 find . |wc -l 2)查看当前文件夹以及子文件夹的文件大小之和 du -s 3)非覆盖目标文件的拷贝(涵盖子目录所有文件、可视化) cp -nrv source/file dest/file 4)设置文件软链接(觉得很像快捷方式) ln -sf TARGET LINK_NAME -s, --symbolic  make symbolic links instead of hard links -f, --force  remove existing destination files 5)设置设备开启启动完成后,执行的命令(貌似像是开机启动项) 修改/etc/rc.local This script will be executed *after* all the other init scripts. You can put your own initialization stuff in here if you don't want to do the full Sys V style init stuff.

02
领券