​更多内核安全、eBPF分析和实践文章,请关注博客和公众号:

CSDN博客:内核功守道
公众号: 内核功守道

概述

F2FS是Flash Friendly File System的简称。该文件系统是由韩国三星电子公司于2012年研发,只提供给运行Linux内核的系统使用,这种文件系统对于NAND闪存类存储介质是非常友好的。并且F2FS是专门为基于 NAND 的存储设备设计的新型开源 flash 文件系统。特别针对NAND 闪存存储介质做了友好设计。F2FS 于2012年12月进入Linux 3.8 内核。目前,F2FS仅支持Linux操作系统。

根据内部几何结构和闪存管理机制(FTL),闪存存储设备有很多不同的属性,所以F2FS的设计者增加了多种参数,不仅用于配置磁盘布局,还可以选择分配和清理算法,优化性能(并行IO提高性能)。

F2FS早期开发者为Jaegeuk Kim,当时是三星员工,但是三星自家的机器没有直接使用F2FS,而是CM开源ROM组有做相关的适配。后来这个开发者被MOTO挖走,于是我们见到了用F2FS的MOTO X系列。后来又去了华为,故而有了全线F2FS的EMUI5.0,号称流畅度提升20%华为的P9和Mate9都使用F2FS,流畅度明显提升。当然F2FS倒没什么版权纠纷,Linux体系下的东西自然遵守开源协定。

对于F2FS,官方文档和其他博主大都从原理和代码的角度来分析,我今天会从实战横向对比EXT4文件系统的视角,带你感受真实的F2FS!

代码范围

  • device/ $platform/device.mk
  • vendor/proprietary/hardware/fstab/$platform/fstab.bin
  • kernel-4.4/arch/arm64/configs/ $platform_n_defconfig
  • external/f2fs-tools/*
  • system/extras/f2fs_utils/*

F2FS架构

F2FS文件系统的数据结构说明:
F2FS使用三种node:inode,直接node,间接node。F2FS分配4KB的空间给一个inode,其中包括929个数据块索引指针,两个一级索引块(直接node)指针,两个二级索引块(间接node)指针,以及一个三级索引块(二级间接node)指针。

一个一级索引块包含1018个数据块指针,一个二级索引块包含1018个一级索引块指针,一个三级索引块包含1018个二级索引块指针。可以索引到一个文件的最大大小是:
4 KB * (929 + 2*1018 + 2*1018*1018 + 1018*1018*1018) := 3.94 TB

F2FS文件系统的标准磁盘布局:

F2FS文件系统的数据结构(node结构):

F2FS和EXT4文件系统比较

  • 碎片整理
    EXT4文件系统:按照EXT文件系统的作者所说的,在分区的空余空间在2%以上的情况下EXT分区是不会产生碎片的。
    F2FS文件系统:为管理磁盘上的大的连续的空间以便快速写入数据,使用Segment Cleaner从重度碎片化的Segment中转移出有效信息,然后将该Segment清理干净用于后续写入数据。

  • 占用空间
    通过DiskInfo可以明确的显示,当Data分区的文件系统格式分别为EXT4和F2FS时所占空间的大小对比:
    从Android系统的角度来看,相同的安卓ROM包,在F2FS文件系统下占用闪存的容量会多一些。

    F2FS文件系统在每一个文件索引节点块中包含了如下f2fs_inode和node_footer。其中f2fs_inode结构中的数据索引区又存在923个数据块指针,每个指针对应一个大小为4KB的数据块,但是在通常情况下系统文件索引并不需要用到所有数据块,在最极端情况下文件大小为4KB时,只需要用到一个数据块,剩下的数据块则处于闲置状态,这就造成了存储容量在一定程度上的空间浪费,也就是同样一部手机,在相同的安卓系统中,F2FS文件系统下,闪存容量的占用会相对高一些。

  • 数据恢复
    数据恢复机制和数据写入磁盘的方式密切相关。对于Linux系统,其页缓存机制采用推迟写入的方式写入数据,在内存中被标记为脏的页并不会立即写回磁盘,以确保系统的性能。因此,存在于内存页中的数据在系统发生意外情况时就会丢失。

    对于一种情况,即sync操作时发生在数据写入磁盘后而在元数据写入磁盘前的系统意外,其数据已经写入磁盘但由于没有索引而无法找回,而F2FS提供了相应的恢复机制找回这些文件数据。

  • 集成情况
    现在不管是手机或者其他Android设备集成F2FS比较普遍,但是早期为了兼容性和性能,会把data分区使用F2FS,而系统和缓存都还是EXT4,这样F2FS只会影响到第三方应用一段时间内首次读写文件时的速度,这只是使用流畅度的一部分而已。此外比较重要的系统和较小的缓存分区仍采用EXT4。

  • 读写速度

左边EXT4文件系统, 右边F2FS文件系统

连续读写:
二者的连续读写性能没有太大的变化。

随机读写:
F2FS比EXT4的随机读取性能提升了25%左右;但是随机写入速度,F2FS比EXT4文件系统有了飞跃的提升,随机写入性能提升了三倍还多。

由于随机写入的性能大大提升了,在类似软件安装和系统重启中,要大量写入小文件的情况下,F2FS文件系统下有非常喜人的变化。

性能测试

  • 使用工具AdroBench.apk和安兔兔测试

  • 不同场景测试

横向对比EXT4,带你感受真实的Linux文件系统F2FS相关推荐

  1. linux文件系统什么格式转换,什么是Ext2,Ext3和Ext4以及如何创建和转换Linux文件系统...

    我用我的Fedora旧系统进行测试,我从ext2转换为ext3,EXT2 到ext4和ext3到ext4文件系统成功. 按照本指南任何人都可以巧妙地转换自己的文件系统,但我仍然想提醒你将在此之前,因为 ...

  2. Hbase、Kudu和ClickHouse横向对比

    好记忆不如烂笔头,能记下点东西,就记下点,有时间拿出来看看,也会发觉不一样的感受. 目录 1 前言 2 安装部署方式对比 3 组成架构对比 4 基本操作对比 4.1 数据读写操作 4.2 数据查询操作 ...

  3. 11款当前主流平板芯片横向对比评测

    本篇文章是接续年初所作 <五款主流平板芯片横向对比评测> 之后的最新补充,加入了近期国内比较热门的新方案一起做比较. 在快要进入2011下半年之际,重新回顾起上半年的平板市场,发展过程可用 ...

  4. 第三方Android应用市场横向对比大测评

    第三方Android应用市场横向对比大测评 App Store在苹果整个商业模型中占据了不可替代的核心角色,除越狱之外,App Store是iPhone和iPad所有应用软件的唯一获取途径.同样是应用 ...

  5. Linux_linux常用工具---闲杂篇(除了vim, 还有哪些常用的牛逼的编辑器, 并能够横向对比编辑器之间的区别和优缺点.)

    vim自行查找资料, 自行配置插件. 借鉴别人的 " 显示相关 """"""""""&qu ...

  6. 横向对比5大开源语音识别工具包,CMU Sphinx最佳

    目前开源世界里存在多种不同的语音识别工具包,它们为开发者构建应用提供了很大帮助.这些工具各有哪些优劣?数据科学公司 Silicon Valley Data Science 为我们带来了 5 种流行工具 ...

  7. 资源 | 横向对比5大开源语音识别工具包,CMU Sphinx最佳

    选自svds 作者:Cindi Thompson 机器之心编译 参与:李泽南.Smith目前开源世界里存在多种不同的语音识别工具包,它们为开发者构建应用提供了很大帮助.这些工具各有哪些优劣?数据科学公 ...

  8. 2020年国内 IoT物联网平台横向对比报告

    金秋十月,丹桂飘香,中秋巧遇国庆! 值此佳节,我们为 IoT 物联网领域的广大开发者们带来了<2020年国内 IoT物联网云平台横向对比报告>. 此<报告>与Gartner和I ...

  9. 举个栗子!Tableau 技巧(152):横向对比堆叠柱形图的各部分占比

    柱形图因其一目了然的特点,成为最常用的分析图表之一.而堆叠柱形图则可以更清晰地比较某一个维度中不同类型数据之间的差异,也深受分析用户推崇. 很多 Tableau 用户在使用堆叠柱形图时,会遇到这样的问 ...

  10. tableau的动态参数和横向对比堆叠柱形图

    利用到的知识点:利用参数实现动态价格带,通过更改字段的计算方式时间横向对比. 这里以价格带分析作为一个例子. 1.添加一个参数:价格带间隔,即价格带计算的步长. 2.添加计算字段:价格带的定义: 3. ...

最新文章

  1. Linux虚拟内存和物理内存精华【美】
  2. BF法-字符模式匹配
  3. php中instanceof的使用
  4. python怎么打包压缩文件_Python打包文件夹的方法小结(zip,tar,tar.gz等)
  5. [Wix] Wix代码生成器:tallow
  6. 35岁以上的程序员们,后来都干什么去了?
  7. win7分区软件_神奇的工作室win7旗舰版重装系统连不上网怎么解决
  8. 关于tomcat启动失败的一个原因
  9. python与mysql数据库如何连接_如何连接Python中的MySQL数据库?
  10. Queue--队列(c语言简单实现)
  11. linux mysql 数据恢复_怎样恢复Mysql数据库误删除后的数据
  12. i.MX6ULL处理器GPIO寄存器配置原理
  13. 哪吒票房一路飙升100行python代码抓取豆瓣短评
  14. 高考数学计算机题,高考数学大题
  15. 随机产生四位,任意位或者范围数字方法
  16. java 构造器 血药主题_Day08-面向对象编程,Java构造器
  17. 爬虫实战:英雄联盟手游能“干掉”王者荣耀?微博4.3亿网友吵翻了……
  18. Canvas 绘制圆形图片、绘制圆角矩形图片
  19. 《资管新规》深度解读
  20. 对建立奉贤区区级工程技术中心的企业给予30万元奖励

热门文章

  1. Activiti6.0 - 核心数据库表及字段注释说明
  2. 服务器ghost备份后无法进入系统还原,如下图,电脑开不起来了,重新ghost恢复备份的系统后启动依旧蓝屏,怎么办?...
  3. FFT FNT 简要整理
  4. tomcat8.0安装及配置教程
  5. Android下ping的简单工具类
  6. 计算机应用基础教程学什么,[电脑基础知识]计算机应用基础教程学习.ppt
  7. 游戏开发中的脚本语言
  8. Golang-PKCS8
  9. imewlconverter 制作Rime词库
  10. linux九九乘法表代码,C语言输出九九乘法表代码及解析