0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫(xiě)文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

F2FS文件系統(tǒng)的數(shù)據(jù)結(jié)構(gòu)

Linux閱碼場(chǎng) ? 來(lái)源:Linux閱碼場(chǎng) ? 作者:Linux閱碼場(chǎng) ? 2022-09-15 09:06 ? 次閱讀

一、概述

F2FS是Flash Friendly File System的簡(jiǎn)稱(chēng)。該文件系統(tǒng)是由韓國(guó)三星電子公司于2012年研發(fā),只提供給運(yùn)行Linux內(nèi)核的系統(tǒng)使用,這種文件系統(tǒng)對(duì)于NAND閃存類(lèi)存儲(chǔ)介質(zhì)是非常友好的。并且F2FS是專(zhuān)門(mén)為基于 NAND 的存儲(chǔ)設(shè)備設(shè)計(jì)的新型開(kāi)源 flash 文件系統(tǒng)。特別針對(duì)NAND 閃存存儲(chǔ)介質(zhì)做了友好設(shè)計(jì)。F2FS 于2012年12月進(jìn)入Linux 3.8 內(nèi)核。目前,F(xiàn)2FS僅支持Linux操作系統(tǒng)。

根據(jù)內(nèi)部幾何結(jié)構(gòu)和閃存管理機(jī)制(FTL),閃存存儲(chǔ)設(shè)備有很多不同的屬性,所以F2FS的設(shè)計(jì)者增加了多種參數(shù),不僅用于配置磁盤(pán)布局,還可以選擇分配和清理算法,優(yōu)化性能(并行IO提高性能)

F2FS早期開(kāi)發(fā)者為Jaegeuk Kim,當(dāng)時(shí)是三星員工,但是三星自家的機(jī)器沒(méi)有直接使用F2FS,而是CM開(kāi)源ROM組有做相關(guān)的適配。后來(lái)這個(gè)開(kāi)發(fā)者被MOTO挖走,于是我們見(jiàn)到了用F2FS的MOTO X系列。后來(lái)又去了華為,故而有了全線F2FS的EMUI5.0,號(hào)稱(chēng)流暢度提升20%華為的P9和Mate9都使用F2FS,流暢度明顯提升。當(dāng)然F2FS倒沒(méi)什么版權(quán)糾紛,Linux體系下的東西自然遵守開(kāi)源協(xié)定。

對(duì)于F2FS,官方文檔和其他博主大都從原理和代碼的角度來(lái)分析,我今天會(huì)從實(shí)戰(zhàn)橫向?qū)Ρ菶XT4文件系統(tǒng)的視角,帶你感受真實(shí)的F2FS!

二、F2FS架構(gòu)

F2FS文件系統(tǒng)的數(shù)據(jù)結(jié)構(gòu)說(shuō)明:
F2FS使用三種node:inode,直接node,間接node。F2FS分配4KB的空間給一個(gè)inode,其中包括929個(gè)數(shù)據(jù)塊索引指針,兩個(gè)一級(jí)索引塊(直接node)指針,兩個(gè)二級(jí)索引塊(間接node)指針,以及一個(gè)三級(jí)索引塊(二級(jí)間接node)指針。

一個(gè)一級(jí)索引塊包含1018個(gè)數(shù)據(jù)塊指針,一個(gè)二級(jí)索引塊包含1018個(gè)一級(jí)索引塊指針,一個(gè)三級(jí)索引塊包含1018個(gè)二級(jí)索引塊指針??梢运饕揭粋€(gè)文件的最大大小是:

4 KB * (929 + 2*1018 + 2*1018*1018 + 1018*1018*1018) := 3.94 TB

F2FS文件系統(tǒng)的標(biāo)準(zhǔn)磁盤(pán)布局:
9f10b528-348b-11ed-ba43-dac502259ad0.png
F2FS文件系統(tǒng)的數(shù)據(jù)結(jié)構(gòu)(node結(jié)構(gòu)):
9fa55124-348b-11ed-ba43-dac502259ad0.png

三、F2FS和EXT4文件系統(tǒng)比較

碎片整理
EXT4文件系統(tǒng):按照EXT文件系統(tǒng)的作者所說(shuō)的,在分區(qū)的空余空間在2%以上的情況下EXT分區(qū)是不會(huì)產(chǎn)生碎片的。
F2FS文件系統(tǒng):為管理磁盤(pán)上的大的連續(xù)的空間以便快速寫(xiě)入數(shù)據(jù),使用Segment Cleaner從重度碎片化的Segment中轉(zhuǎn)移出有效信息,然后將該Segment清理干凈用于后續(xù)寫(xiě)入數(shù)據(jù)。

占用空間
通過(guò)DiskInfo可以明確的顯示,當(dāng)Data分區(qū)的文件系統(tǒng)格式分別為EXT4和F2FS時(shí)所占空間的大小對(duì)比:9ffa8824-348b-11ed-ba43-dac502259ad0.png從Android系統(tǒng)的角度來(lái)看,相同的安卓ROM包,在F2FS文件系統(tǒng)下占用閃存的容量會(huì)多一些。

F2FS文件系統(tǒng)在每一個(gè)文件索引節(jié)點(diǎn)塊中包含了如下f2fs_inode和node_footer。其中f2fs_inode結(jié)構(gòu)中的數(shù)據(jù)索引區(qū)又存在923個(gè)數(shù)據(jù)塊指針,每個(gè)指針對(duì)應(yīng)一個(gè)大小為4KB的數(shù)據(jù)塊,但是在通常情況下系統(tǒng)文件索引并不需要用到所有數(shù)據(jù)塊,在最極端情況下文件大小為4KB時(shí),只需要用到一個(gè)數(shù)據(jù)塊,剩下的數(shù)據(jù)塊則處于閑置狀態(tài),這就造成了存儲(chǔ)容量在一定程度上的空間浪費(fèi),也就是同樣一部手機(jī),在相同的安卓系統(tǒng)中,F(xiàn)2FS文件系統(tǒng)下,閃存容量的占用會(huì)相對(duì)高一些。

數(shù)據(jù)恢復(fù)
數(shù)據(jù)恢復(fù)機(jī)制和數(shù)據(jù)寫(xiě)入磁盤(pán)的方式密切相關(guān)。對(duì)于Linux系統(tǒng),其頁(yè)緩存機(jī)制采用推遲寫(xiě)入的方式寫(xiě)入數(shù)據(jù),在內(nèi)存中被標(biāo)記為臟的頁(yè)并不會(huì)立即寫(xiě)回磁盤(pán),以確保系統(tǒng)的性能。因此,存在于內(nèi)存頁(yè)中的數(shù)據(jù)在系統(tǒng)發(fā)生意外情況時(shí)就會(huì)丟失。

對(duì)于一種情況,即sync操作時(shí)發(fā)生在數(shù)據(jù)寫(xiě)入磁盤(pán)后而在元數(shù)據(jù)寫(xiě)入磁盤(pán)前的系統(tǒng)意外,其數(shù)據(jù)已經(jīng)寫(xiě)入磁盤(pán)但由于沒(méi)有索引而無(wú)法找回,而F2FS提供了相應(yīng)的恢復(fù)機(jī)制找回這些文件數(shù)據(jù)。

集成情況
現(xiàn)在不管是手機(jī)或者其他Android設(shè)備集成F2FS比較普遍,但是早期為了兼容性和性能,會(huì)把data分區(qū)使用F2FS,而系統(tǒng)和緩存都還是EXT4,這樣F2FS只會(huì)影響到第三方應(yīng)用一段時(shí)間內(nèi)首次讀寫(xiě)文件時(shí)的速度,這只是使用流暢度的一部分而已。此外比較重要的系統(tǒng)和較小的緩存分區(qū)仍采用EXT4。

讀寫(xiě)速度
a062a18e-348b-11ed-ba43-dac502259ad0.png左邊EXT4文件系統(tǒng), 右邊F2FS文件系統(tǒng)

連續(xù)讀寫(xiě):
二者的連續(xù)讀寫(xiě)性能沒(méi)有太大的變化。

隨機(jī)讀寫(xiě):
F2FS比EXT4的隨機(jī)讀取性能提升了25%左右;但是隨機(jī)寫(xiě)入速度,F(xiàn)2FS比EXT4文件系統(tǒng)有了飛躍的提升,隨機(jī)寫(xiě)入性能提升了三倍還多。

由于隨機(jī)寫(xiě)入的性能大大提升了,在類(lèi)似軟件安裝和系統(tǒng)重啟中,要大量寫(xiě)入小文件的情況下,F(xiàn)2FS文件系統(tǒng)下有非常喜人的變化。

四、性能測(cè)試

使用工具AdroBench.apk和安兔兔測(cè)試

a09a1e3e-348b-11ed-ba43-dac502259ad0.png

不同場(chǎng)景測(cè)試

a0e3545a-348b-11ed-ba43-dac502259ad0.png

審核編輯:彭靜
聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴

原文標(biāo)題:橫向?qū)Ρ菶XT4,帶你感受真實(shí)的Linux文件系統(tǒng)F2FS

文章出處:【微信號(hào):LinuxDev,微信公眾號(hào):Linux閱碼場(chǎng)】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    用于管理文件方法和數(shù)據(jù)結(jié)構(gòu)案例分析

    文件系統(tǒng)是在存儲(chǔ)設(shè)備中(SD Card、NAND Flash…)組織文件的方法和數(shù)據(jù)結(jié)構(gòu),用于管理文件。AWorks定義了文件系統(tǒng)的通用接口
    的頭像 發(fā)表于 08-03 09:28 ?8762次閱讀

    面向AWorks框架管理文件的方法和數(shù)據(jù)結(jié)構(gòu)

    文件系統(tǒng)是在存儲(chǔ)設(shè)備中(SD Card、NAND Flash…)組織文件的方法和數(shù)據(jù)結(jié)構(gòu),用于管理文件。AWorks定義了文件系統(tǒng)的通用接口
    的頭像 發(fā)表于 06-05 09:18 ?5553次閱讀
    面向AWorks框架管理<b class='flag-5'>文件</b>的方法和<b class='flag-5'>數(shù)據(jù)結(jié)構(gòu)</b>

    基于Buildroot的Linux系統(tǒng)構(gòu)建之根文件系統(tǒng)

    基本的Linux根文件系統(tǒng)是Unix文件夾目錄層次結(jié)構(gòu),skeleton是構(gòu)建根文件系統(tǒng)的基礎(chǔ)。   skeleton配置入口:   System configuration --
    發(fā)表于 04-01 10:46 ?2563次閱讀

    嵌入式Linux啟動(dòng)時(shí)間優(yōu)化的秘密之二文件系統(tǒng)

    +SquashFS 對(duì)于塊文件系統(tǒng),特性各異: ext4:最適合較大的分區(qū),良好的讀寫(xiě)性能。 xfs,jfs,reiserfs:在某些讀或?qū)憟?chǎng)景中也可能很好。 btrfs,f2fs:利用閃存塊設(shè)
    發(fā)表于 04-03 17:28 ?5087次閱讀
    嵌入式Linux啟動(dòng)時(shí)間優(yōu)化的秘密之二<b class='flag-5'>文件系統(tǒng)</b>

    Linux平臺(tái)/proc虛擬文件系統(tǒng)詳解

    Linux 內(nèi)核提供了一種通過(guò) /proc 文件系統(tǒng),在運(yùn)行時(shí)訪問(wèn)內(nèi)核內(nèi)部數(shù)據(jù)結(jié)構(gòu)、改變內(nèi)核設(shè)置的機(jī)制。proc文件系統(tǒng)是一個(gè)偽文件系統(tǒng)(即虛擬文件
    發(fā)表于 06-08 10:49 ?1424次閱讀
    Linux平臺(tái)/proc虛擬<b class='flag-5'>文件系統(tǒng)</b>詳解

    FATfs文件系統(tǒng)解析

    文件系統(tǒng)所用的數(shù)據(jù)結(jié)構(gòu)和各種函數(shù)聲明,再就是diskio.h,了解與介質(zhì)相關(guān)的數(shù)據(jù)結(jié)構(gòu)和操作函數(shù)。ff.c這個(gè)文件相對(duì)較大,可以在最后將所實(shí)現(xiàn)的函數(shù)大致掃描一遍,之后根據(jù)用戶(hù)應(yīng)用層程序
    發(fā)表于 07-18 11:13

    嵌入式文件系統(tǒng)μC/FS的日志使用

    ,基于FAT的文件系統(tǒng)解決方案可能是增加系統(tǒng)可靠性的一個(gè)的來(lái)源,為了提供掉電保護(hù),F(xiàn)AT實(shí)現(xiàn)需配備日志模塊。日志模塊通過(guò)將更改的意圖記錄在 “日記”數(shù)據(jù)結(jié)構(gòu)中,來(lái)跟蹤尚未提交文件系統(tǒng)
    發(fā)表于 09-19 16:41

    怎樣將userdata區(qū)文件系統(tǒng)f2fs換為Ext4呢

    怎樣將userdata區(qū)文件系統(tǒng)f2fs換為Ext4呢?有什么方法嗎?
    發(fā)表于 02-17 07:35

    怎樣將RK3399中data文件系統(tǒng)分區(qū)的格式由原先的f2fs格式變至ext4格式呢

    最近應(yīng)需求修改了AIO-3399C中/data文件系統(tǒng)分區(qū)的格式,由原先的f2fs格式變至ext4格式。可是明明f2fs格式分區(qū)的性能與IO讀取速率都更優(yōu)于ext4?,F(xiàn)將鄙人的一些小心得分享于大家
    發(fā)表于 06-24 10:37

    Linux虛擬文件系統(tǒng)實(shí)現(xiàn)技術(shù)探討

    文章論述了 Linux 文件系統(tǒng)的邏輯關(guān)系和邏輯結(jié)構(gòu),對(duì)VFS 中幾個(gè)主要的數(shù)據(jù)結(jié)構(gòu)進(jìn)行了分析,剖析了Linux 文件系統(tǒng) 中一個(gè)物理文件系統(tǒng)
    發(fā)表于 06-08 17:51 ?32次下載
    Linux虛擬<b class='flag-5'>文件系統(tǒng)</b>實(shí)現(xiàn)技術(shù)探討

    STM32F10x_3.5版固件的模塊、數(shù)據(jù)結(jié)構(gòu)和索引、文件列表等資料

    本文檔的主要內(nèi)容詳細(xì)介紹的是STM32F10x_3.5版固件的模塊、數(shù)據(jù)結(jié)構(gòu)和索引、文件列表等資料。
    發(fā)表于 10-17 16:53 ?0次下載
    STM32<b class='flag-5'>F</b>10x_3.5版固件的模塊、<b class='flag-5'>數(shù)據(jù)結(jié)構(gòu)</b>和索引、<b class='flag-5'>文件</b>列表等資料

    可以了解的Linux 文件系統(tǒng)結(jié)構(gòu)

    Linux中的文件是什么?它的文件系統(tǒng)又是什么?那些配置文件又在哪里?我下載好的程序保存在哪里了?在 Linux 中文件系統(tǒng)是標(biāo)準(zhǔn)結(jié)構(gòu)的嗎?
    發(fā)表于 04-27 14:06 ?706次閱讀
    可以了解的Linux <b class='flag-5'>文件系統(tǒng)</b><b class='flag-5'>結(jié)構(gòu)</b>

    Debian可以從F2FS文件系統(tǒng)運(yùn)行了

    不少用戶(hù)希望通過(guò)將 Flash-Friendly File-System (F2FS) 作為根文件系統(tǒng)來(lái)啟動(dòng)和運(yùn)行 Debian,現(xiàn)在這個(gè)目標(biāo)將有望達(dá)成了。
    的頭像 發(fā)表于 01-13 14:37 ?2596次閱讀

    事務(wù)性日志結(jié)構(gòu)文件系統(tǒng)的設(shè)計(jì)及實(shí)現(xiàn)

    本文發(fā)表于FAST 2022,探討日志結(jié)構(gòu)文件系統(tǒng)層面的事務(wù)支持。本文主要對(duì)F2FS進(jìn)行了支持事務(wù)的修改,實(shí)現(xiàn)了支持ACID事務(wù)特性的文件系統(tǒng)層面支持。本文通過(guò)實(shí)驗(yàn)測(cè)試了SQLite和
    的頭像 發(fā)表于 10-16 16:01 ?670次閱讀
    事務(wù)性日志<b class='flag-5'>結(jié)構(gòu)</b><b class='flag-5'>文件系統(tǒng)</b>的設(shè)計(jì)及實(shí)現(xiàn)

    Linux的文件系統(tǒng)特點(diǎn)

    ,近期經(jīng)常被讀取和寫(xiě)入,文件系統(tǒng)應(yīng)該有緩存層。 文件應(yīng)該用文件夾的形式組織起來(lái),方便管理和查詢(xún)。 Linux內(nèi)核要在自己的內(nèi)存里面維護(hù)一套數(shù)據(jù)結(jié)構(gòu),來(lái)保存哪些
    的頭像 發(fā)表于 11-09 14:48 ?1098次閱讀
    Linux的<b class='flag-5'>文件系統(tǒng)</b>特點(diǎn)