F2FS - F2FS

F2FS
ӘзірлеушілерSamsung Electronics, Motorola Mobility, Huawei және Google
Толық атыФлешке қолайлы файлдық жүйе
Таныстырылдыv3.8, 2012-12-20[1] бірге Linux
Құрылымдар
Каталог мазмұныкөп деңгейлі хэш-кесте
Файлды бөлунүктелік карта (бос орын), кесте
ЖүктелетінИә, GRUB 2.04 бастап (2019-07-05)
Шектер
Макс. көлем мөлшері16 Туберкулез
Макс. файл өлшемі3.94 Туберкулез
Макс. файлдар саныКөлемнің өлшеміне байланысты
Макс. файл атауының ұзындығы512 байт[2]
Ерекшеліктер
Жазылған күндермодификация (mtime), атрибутты өзгерту (ctime), қол жетімділік (atime)
Шешім күні1 нс
АтрибуттарPOSIX, кеңейтілген атрибуттар
Файлдық жүйеге арналған рұқсаттарPOSIX, ACL
Мөлдір қысуLZO, LZ4 (Linux 5.6 бастап),[3] zstd (Linux 5.7 бастап)[4]
Мөлдір шифрлауИә
Басқа
Қолдау көрсетіледі операциялық жүйелерLinux және Android
Веб-сайтf2fs.wiki. ядро.org

F2FS (Флешке қолайлы файлдық жүйе) Бұл флэш-файл жүйесі бастапқыда Samsung Electronics үшін Linux ядросы.[5]

F2FS үшін мотив а құру болды файлдық жүйе сипаттамаларын басынан бастап ескереді NAND флэш-жады - негізделген сақтау құрылғылары (мысалы қатты күйдегі дискілер, eMMC, және SD мобильді құрылғылардан бастап серверлерге дейінгі компьютерлік жүйелерде кеңінен қолданылатын карталар).

F2FS а негізінде жасалған журналдың құрылымдық файлдық жүйесі сақтаудың жаңа түрлеріне бейімделген тәсіл. Джейгук Ким, F2FS-тің негізгі авторы кейбір белгілі мәселелерді шешетінін мәлімдеді[5] сияқты ескі журнал құрылымды файлдық жүйелер қарлы эффект туралы кезбе ағаштар және жоғары тазарту үстіндегі шығындар. Сонымен қатар, NAND-ге негізделген сақтау құрылғысы оның ішкі геометриясына немесе флэш-жадыны басқару схемасына сәйкес әр түрлі сипаттамаларды көрсетеді (мысалы, Flash Translation Layer немесе FTL), ол дискідегі орналасуды конфигурациялау үшін ғана емес, сонымен қатар бөлу және тазалау алгоритмдерін таңдау үшін де әртүрлі параметрлерді қолдайды.

Ерекшеліктер

  • Көп басты журналдар
  • Каталог жазбаларына арналған көп деңгейлі хэш-кесте
  • Статикалық / динамикалық деректерді ыстық және суық бөлу
  • Адаптивті каротаж сұлбасы
  • Конфигурациялық операциялық блоктар
  • Қос бақылау бекеті
  • Артқа және алға айналдыруды қалпына келтіру
  • Үйме стиліндегі блокты бөлу
  • TRIM / FITRIM қолдау[6]
  • Онлайн фс дефрагментация / файлды дефрагментациялау[7]
  • Кірістірілген xattrs[8]/ деректер[9]/ дир[10]
  • Желіден тыс файлдық жүйені тексеру (Сәйкессіздіктерді тексеріп, түзетіңіз[11])
  • Атомдық операциялар[12]
  • Файлдық жүйе деңгейіндегі шифрлау[13]
  • Желіден тыс өлшемін өзгерту (кішірейтуге қолдау көрсетілмейді.)[14]
  • Ішкі мәліметтер мезгіл-мезгіл шайқалады[15]
  • Кэшті кеңейту[16]
  • LZO немесе LZ4 қолдана отырып файлды мөлдір түрде қысу (Linux 5.6 көмегімен),[3] немесе zstd (Linux 5.7 көмегімен)[4]

Дизайн

Дискідегі орналасу

F2FS бүкіл көлемді әрқайсысы 2 МБ-қа бекітілген сегменттер санына бөледі. Бөлім дәйекті сегменттерден тұрады, ал аймақ секциялар жиынтығынан тұрады. Әдепкі бойынша бөлім мен аймақ өлшемдері бірдей өлшемге қойылады, бірақ пайдаланушылар өлшемді оңай өзгерте алады mkfs.

F2FS бүкіл көлемді алты аймаққа бөледі, ал жоғарғы блок аймағынан басқалары төменде сипатталғандай бірнеше сегменттерден тұрады.

Superblock (SB)
SB бөлімнің басында орналасқан. Файлдық жүйенің бүлінуіне жол бермейтін екі дана бар. Онда бөлім туралы негізгі ақпарат және кейбір F2FS параметрлері бар.
Бақылау пункті (CP)
CP құрамында файлдық жүйелер туралы ақпарат, жарамды NAT / SIT жиынтықтары үшін растрлық карталар, жетімсіз инодтар тізімдері және ағымдағы белсенді сегменттердің жиынтық жазбалары бар.
Сегменттер туралы ақпарат кестесі (SIT)
SIT барлық негізгі аймақ блоктарының жарамды блоктары мен растрлық кескіндерін қамтиды.
Түйін мекен-жайы кестесі (NAT)
NAT - бұл негізгі аймақтың түйін блоктарына арналған адрестік кесте.
Сегменттің жиынтық аймағы (SSA)
SSA негізгі аймақ деректері мен түйін блоктарының иесі туралы ақпаратты қамтитын жазбаларды қамтиды.
Негізгі аймақ
Негізгі аймақта файлдар мен каталогтар туралы мәліметтер және олардың индекстері бар.

Файлдық жүйе мен флэш-жады арасындағы үйлесімділікті болдырмау үшін F2FS CP-тің бастау блогының мекен-жайын сегменттің өлшемімен сәйкестендіреді. Сондай-ақ, SSA аймағындағы кейбір сегменттерді резервтеу арқылы Main Area старттық адресін аймақ өлшемімен сәйкестендіреді.

Метамәліметтер құрылымы

F2FS бақылау жүйесінің схемасын файл жүйесінің тұтастығын сақтау үшін қолданады. Орнату кезінде F2FS алдымен CP аймағын сканерлеу арқылы бақылау нүктесінің соңғы деректерін табуға тырысады. Сканерлеу уақытын қысқарту үшін F2FS CP-дің екі данасын ғана қолданады. Олардың біреуі әрқашан көлеңкеден көшіру механизмі деп аталатын соңғы жарамды деректерді көрсетеді. CP-тен басқа NAT және SIT көлеңкелі көшіру механизмін қолданады. Файлдық жүйенің бірізділігі үшін әрбір CP NAT және SIT көшірмелері жарамды екенін көрсетеді.

Индекс құрылымы

Мәліметтердің негізгі құрылымы - «түйін». Дәстүрлі файлдық құрылымдарға ұқсас, F2FS-те үш типті түйіндер бар: инод, тікелей түйін, жанама түйін. Төменде сипатталғандай, F2FS индикаторлық блокқа 923 мәліметтер блогының индекстерін, екі тікелей түйіннің көрсеткіштерін, екі жанама түйіннің көрсеткіштерін және бір жанама түйіннің көрсеткіштерін қамтитын инодты блокқа береді. Тік түйін блогында мәліметтер блогының 1018 индекстері, ал жанама түйіндер блогында 1018 түйіндер блоктарының индекстері болады. Осылайша, бір инодты блок (яғни, файл) мыналарды қамтиды:

4 КБ × (923 + 2 × 1018 + 2 × 1018.)2 + 10183) = 3,94 ТБ

Барлық түйін блоктары NAT арқылы бейнеленетініне назар аударыңыз, демек әр түйіннің орналасуы NAT арқылы аударылады. Ағаштардағы ақаулықты азайту үшін F2FS парақ деректерін жазудан туындаған түйін жаңартуларының таралуын тоқтата алады.

Каталог құрылымы

Каталог жазбасы (стоматология) келесі атрибуттардан тұратын 11 байтты алады.

Каталогтың құрылымы
хэшФайл атауының хэш мәні
мен жоқInode нөмір
ленФайл атауының ұзындығы
түріФайл түрі, мысалы каталог, символ сілтемесі және т.б.

Стоматологиялық блок 214 стоматологиялық слоттан және файл атауларынан тұрады. Нүктелік карта әр стоматологияның жарамды-жарамсыздығын білдіру үшін қолданылады. Стоматологиялық блок 4 Кбайт алады және келесі құрамнан тұрады:

Тіс блогы (4 К) = растрлық кескін (27 байт) + сақталған (3 байт) + тісшелер (11 * 214 байт) + файл атауы (8 * 214 байт)

F2FS каталог құрылымына арналған көп деңгейлі хэш кестелерін орындайды. Әр деңгейде төменде көрсетілгендей хэш-шелектердің арнайы саны бар хэш-кесте бар. «A (2B)» шелектің құрамында 2 мәліметтер блогы бар екенін білдіретінін ескеріңіз.

Мерзім
A шелекті көрсетеді
B блокты білдіреді
N MAX_DIR_HASH_DEPTH көрсетеді
деңгей # 0 A (2B) деңгей # 1 A (2B) - A (2B) деңгей # 2 A (2B) - A (2B) - A (2B) - A (2B) ... деңгей # N / 2 A (2B) - A (2B) - A (2B) - A (2B) - A (2B) - ... - A (2B) ... деңгей #NA (4B) - A (4B) - A (4B) ) - A (4B) - A (4B) - ... - A (4B)

F2FS каталогтан файл атауын тапқан кезде алдымен файл атауының хэш мәні есептеледі. Содан кейін, F2FS хэш кестесін # 0 деңгейінде қарап, файл атауы мен оның инод нөмірінен тұратын стоматологияны табады. Егер табылмаған болса, F2FS келесі хэш кестені # 1 деңгейінде тексереді. Осылайша, F2FS хэш кестелерін әр деңгейдегі қадамдарды 1-ден біртіндеп сканерлейді N. Әр деңгейде F2FS келесі теңдеумен анықталған бір ғана шелекті сканерлеуі керек, ол O (журнал (файлдар)) күрделілігін көрсетеді.

 #n деңгейінде сканерлеуге арналған шелек нөмірі = (хэш мәні)% (#n деңгейдегі # шелек)

Файлдар жасалған жағдайда, F2FS файл атауын қамтитын бос қатарлы бос орындарды табады. F2FS барлық деңгейлердегі хэш кестелердегі бос слоттарды 1-ден бастап іздейді N іздеу әрекеті сияқты.

Әдепкі блокты бөлу

Жұмыс кезінде F2FS «Негізгі аймақ» ішіндегі алты белсенді журналды басқарады: Ыстық / Жылы / Суық түйін және Ыстық / Жылы / Суық деректер.

Блоктарды бөлу саясаты
Ыстық түйінҚұрамында каталогтардың тікелей түйінді блоктары бар.
Жылы түйінҚұрамында ыстық түйін блоктарынан басқа тікелей түйін блоктары бар.
Суық түйінЖанама түйін блоктарын қамтиды.
Ыстық деректерҚұрамында стоматологиялық блоктар бар.
Жылы деректерҚұрамында ыстық және суық деректер блоктарынан басқа деректер блоктары бар.
Суық деректерҚұрамында мультимедиялық деректер немесе көшірілген деректер блоктары бар.

LFS кеңістікті басқаруға арналған екі схемаға ие: бұрандалы журнал және көшіру және тығыздау. Тазарту деп аталатын көшіру және тығыздау схемасы өте жақсы дәйекті жазуды көрсететін құрылғыларға өте қолайлы, өйткені жаңа деректерді жазу үшін барлық уақытта ақысыз сегменттер қызмет етеді. Алайда, ол жоғары пайдалану кезінде үстіңгі қабатты тазартудан зардап шегеді. Керісінше, бұрандалы журнал схемасы кездейсоқ жазулардан зардап шегеді, бірақ тазалау процедурасы қажет емес. F2FS гибридті схеманы қабылдайды, мұнда көшіру және тығыздау схемасы әдепкі бойынша қабылданады, бірақ саясат файлдық жүйе күйіне сәйкес бұрандалы журнал схемасына динамикалық түрде өзгертіледі.

F2FS-ті жарқылға негізделген жадпен сәйкестендіру үшін F2FS сегментті бөлімнің бірлігіне бөледі. F2FS бөлімнің мөлшері FTL-де қоқыс жинау бірлігінің өлшемімен бірдей болады деп күтеді. FTL-дегі карта түйіршіктілігіне қатысты F2FS белсенді журналдардың әр бөлімін мүмкіндігінше әр түрлі аймақтарға бөледі. FTL белсенді журнал деректерін карта түйіршіктігіне сәйкес бір бөлу бірлігіне жаза алады.

Тазалау процесі

F2FS тазалауды сұраныс бойынша да, фонда да жүргізеді. Тапсырыс бойынша тазалау VFS қоңырауларына қызмет көрсететін ақысыз сегменттер болмаған кезде іске қосылады. Фонды тазартқыш ядро ​​жіпімен орындалады және жүйе жұмыс істемей тұрған кезде тазалау жұмысын бастайды.

F2FS құрбандарды таңдаудың екі саясатын қолдайды: ашкөздік және шығын-пайда алгоритмдері. Ашкөздік алгоритмінде F2FS ең аз жарамды блоктар санына ие құрбандық сегментін таңдайды. Пайдалы шығындар алгоритмінде F2FS ашкөздік алгоритмінде кездесетін журналды блоктау проблемасын шешу үшін сегмент жасына және жарамды блоктар санына сәйкес құрбан сегментін таңдайды. F2FS сұраныс бойынша тазалау үшін ашкөздік алгоритмін пайдаланады, ал фондық тазалаушы шығындар мен пайда алгоритмін пайдаланады.

Жәбірленуші сегментіндегі деректердің дұрыс немесе дұрыс еместігін анықтау үшін F2FS растрлық картаны басқарады. Әрбір бит блоктың жарамдылығын білдіреді, ал нүктелік кескін негізгі аймақтағы бүкіл блоктарды қамтитын бит ағынынан тұрады.

Бала асырап алу

Motorola Mobility 2012 жылдан бастап F2FS-ді Moto G / E / X және Droid телефондарында қолданады. Google алдымен F2FS қолданды Nexus 9 2014 жылы.[17] Алайда Google-дің басқа өнімдері F2FS-ді осы уақытқа дейін қолданбады Pixel 3 кірістірілген криптографиялық аппараттық қамтамасыздандырумен F2FS жаңартылған кезде.[18]

Huawei бастап F2FS қолданды Huawei P9 2016 жылы.[19][20] OnePlus 2016 жылы OnePlus 3T бастап F2FS қолданды.[21] ZTE 2019 жылы ZTE Axon 10 Pro бастап F2FS қолданды.[22]

Сондай-ақ қараңыз

Пайдаланылған әдебиеттер

  1. ^ Майкл Ларабел (2012-12-22). «Linux 3.8 ядросына біріктірілген F2FS файлдық жүйесі». Phoronix. Алынған 2016-05-25.
  2. ^ Чангман Ли (2013-04-03). «f2fs: mkfs-тен бас тартуға байланысты f2fs.txt файлын жаңартыңыз». Алынған 2020-02-12.
  3. ^ а б Майкл Ларабел (2019-12-23). «LZO / LZ4 + файлдарын кеңейтуді таңдау бойынша F2FS деректерін сығымдау 2020 жылға дейін». Phoronix. Алынған 2020-04-07.
  4. ^ а б Майкл Ларабел (2020-04-07). «F2FS Linux 5.7 ядросымен Zstd қысуды қолдайды». Phoronix. Алынған 2020-04-07.
  5. ^ а б Джэгук Ким (2012-10-05). «f2fs: флэшке ыңғайлы файлдық жүйені енгізу». Алынған 2016-05-25.
  6. ^ Джэгук Ким (2014-09-22). «f2fs: FITRIM-ді f2fs_ioctl-ге енгізу».
  7. ^ Чао Ю (2015-10-26). «f2fs: файлды дефрагментациялауға қолдау көрсету».
  8. ^ Джэгук Ким (2013-08-26). «f2fs: кірістірілген xattrs үшін жалаушалар қосу».
  9. ^ Хуажун Ли (2013-11-10). «f2fs: кірістірілген деректерді f2fs қолдауын қосу».
  10. ^ Чао Ю (2014-09-24). «f2fs: inline dir қолдау».
  11. ^ Джэгук Ким (2014-09-20). «f2fs-tools: 1.4.0 шығарылымы».
  12. ^ Джэгук Ким (2014-09-25). «f2fs: дерекқор үшін atomic_write мүмкіндігін қолдау».
  13. ^ Джэгук Ким (2015-06-24). «v4.2 үшін f2fs жаңартулары».
  14. ^ Джэгук Ким (2016-04-25). «resize.f2fs: бөлім өлшемін кеңейтуге қолдау».
  15. ^ Чао Ю (2015-12-17). «f2fs: деректерді фонға жіберуді қолдау».
  16. ^ Чао Ю (2015-01-25). «f2fs: rb-tree кэшін қосу».
  17. ^ Смит, Джошуа Хо, Райан. «Google Nexus 9 шолуы». www.anandtech.com. Алынған 2019-05-10.
  18. ^ Фрумусану, Андрей (2018-11-02). «Google Pixel 3 шолуы». www.anandtech.com. Алынған 2019-05-11.
  19. ^ Ларабел, Майкл (2018-12-28). «F2FS Linux 4.21-де Google Pixel қолдайтын файлдық жүйенің көмегімен көптеген түзетулер алады». www.phoronix.com. Алынған 2019-05-10.
  20. ^ Хумрик, Мэтт (2017-05-12). «Huawei P10 және P10 Plus». www.anandtech.com. Алынған 2019-05-11.
  21. ^ Честер, Брэндон. «OnePlus 3T шолу». www.anandtech.com. Алынған 2019-05-10.
  22. ^ «ZTE Axon 10 Pro ресми түрде ашылды: F2FS-ті бірінші қолданған». Gizchina.com. 2019-05-06. Алынған 2019-05-10.

Сыртқы сілтемелер