f2fs学习笔记 -12. f2fs checkpoint[转]

1.前言

本文主要记录checkpoint的过程

2.checkpoint的时机

1.gc: 当空闲segment 不足的时候,可以通过check point 释放。
2.sync:执行sync操作时
3.super_block: super block 的put_super 接口需要通过f2fs_write_checkpoint() 来把没有来得及umount导致的可能不一致的数据重新做一次check point。

3.checkpoint的流程

f2fs_sync_fs
	write_checkpoint(sbi, false, false)
		block_operations(sbi)
		f2fs_submit_bio
		flush_nat_entries(sbi)
		flush_sit_entries(sbi)
		reset_victim_segmap(sbi)
		do_checkpoint(sbi, is_umount)
			sync_meta_pages(sbi, META, LONG_MAX)

write_checkpoint同步元数据,包括cp区域,SIT区域,NAT区域

  1. block_operations(sbi):为执行checkpoint冻结FS操作

  2. f2fs_submit_bio(sbi, DATA, true):提交data的io给block层,同步
    f2fs_submit_bio(sbi, NODE, true): 提交node的io给block层,同步
    f2fs_submit_bio(sbi, META, true): 提交meta的io给block层,同步

  3. flush_nat_entries(sbi):flush dirty的nat entry,如果current segment的summary有空间则更新到此,否则更新到nat区
    flush_sit_entries(sbi):flush dirty的sit entry,如果current segment的summary有空间则更新到此,否则更新到sit区
    注:flush_nat_entries和flush_sit_entries都是将dirty数据flush到page cache,通过do_checkpoint才能真正执行submit_bio实现落盘。

  4. reset_victim_segmap(sbi):

  5. do_checkpoint
    (1)sync_meta_pages:将page cache中NAT和SIT page落盘
    (2)写入cp, orphan node, data summary, node summary

  6. unblock_operations: 解冻FS操作

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值