Souborové systémy

Z MiS
(Rozdíly mezi verzemi)
Přejít na: navigace, hledání
(Vytvoření stránky)
 
(Žurnálování: Upřesněn popis žurnálu a žurnálování.)
 
(Není zobrazeno 23 mezilehlých verzí od 1 uživatele.)
Řádka 1: Řádka 1:
[[Category:VSE]][[Category:Informatika]][[Category:OSY]]
+
[[Category:VSE]][[Category:Informatika]][[Category:OSY]][[Category:Ukládání_dat]]
== Na disk ukládáme: ==
+
*data souborů
+
*metadata
+
** pomocné informace, pomocí kterých data hledáme
+
** vlastník souboru, název souboru, velikost, práva,...
+
  
== Pojmy FS ==
+
== Souborový systém ==
=== Cluster ===
+
; K čemu je souborový systém?
*Základní součást datové oblasti logického disku.
+
* Pevný disk z pohledu HW je pouze dlouhá posloupnost stejně velkých sektorů, do kterých můžeme zapsat data.
*Nejmenší počet sektorů, které mohou tvořit soubor.
+
* Abychom se ale v datech vyznali, potřebujeme je uspořádat do souborů, soubory umístit do složek a ty zase do nadřazených složek.
*Vliv velikosti clusteru na výkon FS
+
* Kromě samotných dat tedy musíme ukládat i pomocné informace.
*Velikost nastavujeme při formátování.
+
 
*Pro celý souborový systém musí být jednotná velikost.
+
; Na disk tedy ukládáme:
=== Žurnálování ===
+
* data (obsah souborů, to, co uživatel chce uložit)
*defaultně struktury, jsou potvrzeny (commit) až po dokončení zápisu dat
+
* ''metadata'' (pomocné informace)
*může být narušeno užitím cache v disku
+
** ke kterému souboru daný kousek dat patří
*Princip:
+
** informace pro vyhledávání: umístění ve složkách, názvy souborů,...
**Chci provádět diskovou operaci
+
** informace pro zabezpečení: vlastník souboru, práva pro přístup,...
***mazat soubor
+
** další pomocné informace
***vytvářet soubor
+
 
***vytvářet složku
+
; Souborový systém
***...
+
<div class="Definice">
**Postup akcí:
+
Souborový systém (FS) je:
***Nejprve do žurnálu zapíši, co budu provádět.
+
# formát zápisu metadat (''„Používám souborový systém ext3.“'')
***Pak provádím diskovou operaci.
+
# označení pro konkrétní metadata na disku (''„Došlo k poškození souborového systému.“)
***Pokud se operace dokončí v pořádku, potvrdím ji v žurnálu.
+
</div>
**Co když dojde k problému?
+
 
***Právě prováděnou operaci musím odvolat.
+
 
*Neřeší ztrátu dat, která se zapisovala!
+
== Formátování disku ==
**Zajišťuje, že nedojde k porušení souborového systému.
+
* Vytváření souborového systému na logickém oddílu se označuje slovem ''formátování disku''.
 +
 
 +
 
 +
== Cluster ==
 +
* Podle konkrétního souborového systému se označuje ''cluster'', ''datový blok'' či ''alokační jednotka''.
 +
* Základní jednotka pro zápis dat do datové oblasti logického disku.
 +
* Každý soubor zabírá vždy minimálně jeden cluster. Jeden cluster může zabírat jeden nebo více sektorů.
 +
* Všechny clustery jsou stejně veliké, velikost nastavujeme při formátování.
 +
* Pro celý souborový systém musí být jednotná velikost.
 +
* Velikost clusteru se obvykle nastavuje na 2&ndash;4&nbsp;kB. (U&nbsp;FAT32 se  musí nastavit větší velikost clusteru, protože rozsah počtu clusterů je malý.)
 +
 
 +
; Vliv velikosti clusteru na výkon FS
 +
* menší clustery: nižší [[Defragmentace#Vnit.C5.99n.C3.AD_.C3.97_vn.C4.9Bj.C5.A1.C3.AD_fragmentace|vnitřní fragmentace'']].
 +
* větší clustery:
 +
*# pokud mám na disku velké soubory, je třeba provést méně dílčích čtení pro načtení velkého souborů.
 +
*# bude docházet k&nbsp;menší [[Defragmentace#Vnit.C5.99n.C3.AD_.C3.97_vn.C4.9Bj.C5.A1.C3.AD_fragmentace|vnější fragmentaci]]
 +
 
 +
== Žurnálování ==
 +
* Způsob práce s diskem, kdy využívám speciální datovou strukturu (''žurnál''), abych zabránil poškození souborového systému při havárii počítače.
 +
* Na disku tedy vyhradím místo, do kterého budu zapisovat v&nbsp;dohodnutém formátu informace o&nbsp;tom, jaké operace na disku právě provádím. (Toto místo budu označovat žurnál.)
 +
 
 +
; Princip
 +
* Když chci provádět diskovou operaci (mazat soubor, měnit nebo vytvářet soubor, vytvářet složku,...), pak:
 +
*# Nejprve do žurnálu zapíši, co budu provádět.
 +
*# Pak provedu diskovou operaci.
 +
*# Pokud se operace dokončí v pořádku, zapíši do žurnálu, že je operace dokončena (commit). (Nebo ji ze žurnálu úplně vymažu.)
 +
 
 +
; Co když dojde k přerušení operace uprosřed (například při havárii počítače)?
 +
* Při příštím spuštění počítače při startu operačního systému zkontrolujeme žurnál a&nbsp;najdeme tam informaci o&nbsp;operacích, které nejsou dokončené.
 +
* Tyto přerušené operace buď dokončíme (pokud to jde), nebo zrušíme všechny dílčí kroky provedené doposud. (Odvoláme tyto operace.)
 +
* Například pokud jsme mazali soubor, můžeme to dokončit, protože je v&nbsp;žurnálu zapsané, který soubor jsme mazali.
 +
* Na druhou stranu když jsme ukládali do nového souboru data z&nbsp;operační paměti, data jsou již ztracena, protože obsah operační paměti se ztratil. Můžeme ale odstranit metadata tohoto nového souboru, aby na disku nezůstal napůl vytvořený soubor s&nbsp;neplatnými daty.
 +
 
 +
<div class="Poznamka">
 +
; Poznámky
 +
* Funkce žurnálování může být narušeno užitím cache v disku. (Disk nahlásí dokončení operace, ale data jsou jen v cache, nikoli fyzicky zapsána na disk. Při havárii počítače se tedy data ztratí, ačkoli v&nbsp;žurnálu jsou vedeny jako dokončené.)
 +
* Žurnálování nevyřeší ztrátu dat, která se nestihla zapisat na pevný disk! Nicméně zajišťuje, že nedojde k porušení souborového systému (metadat).
 +
</div>
 +
 
 +
== Další vlastnosti FS ==
 +
* maximální velikost diskového oddílu,
 +
* maximální velikos souboru,
 +
* podpora nastavení práv,
 +
* možnost vytváření snímků (image),
 +
* ...
  
=== Další vlastnosti ===
 
*vytváření snímků (image)
 
  
 
== Typy souborových systémů ==
 
== Typy souborových systémů ==
*diskové
+
* Diskové
*síťové
+
** Běžně známé FS: NTFS, ext2/ext3/ext4, FAT32, btrfs,...
**nfs
+
** Viz [[Příklady souborových systémů]].
**smb
+
* Síťové (NFS, SMB,...)
*paměťové
+
* Paměťové (<tt>tmpfs</tt>)
**tmpfs
+
* Virtuální (<tt>procfs</tt> &mdash; viz [[Adresář /proc| adresář <tt>/proc</tt>]], <tt>fdfs</tt>)
*virtuální
+
 
**procfs
+
== Související pojmy ==
**fdfs
+
 
 +
=== LVM ===
 +
* Systém pro správu logických oblastí.
 +
* Dělá mezivrstvu mezi operačním systémem a fyzickým rozdělením disku (MBR, GPT,...).
 +
* Umožňuje snadno měnit velikosti logických svazků, zálohovat logické svazky, simulovat RAID atd.
  
== Příklady (diskových) FS: ==
+
=== RAID ===
=== NTFS ===
+
* Využití více fyzických disků pro redundantní ukládání dat.
*šifrování, komprese
+
* Při výpadku jednoho disku nepřijdu o data, data jdou dopočítat z informací na ostatních discích.
*menší clustery než u FAT32
+
* Nicméně nemohu využít celý součet kapacit všech disků, část celkové kapacity je využita pro kontrolní součty.
*názvy souborů v UTF8
+
Režimy: RAID 0, RAID 1, RAID 5,...
  
=== FAT/FAT32/exFAT ===
+
=== TRIM ===
*Pochází z MS-DOSu resp. Windows.
+
* Týká se SSD disků. Jedná se o příkazy ATA/SCSI/PCIe, které disk buď podporuje, nebo nepodporuje (dnešní SSD disky obvykle podporují).
*Dnes na disketách a paměťových kartách
+
* Podle rozhraní používají disky jiné příkazy, princip je ale stejný: TRIM u&nbsp;ATA (SATA rozhraní), UNMAP u&nbsp;SCSI rozhraní, DEALLOCATE u&nbsp;NVMe (PCIe rozhraní).
*FAT32
+
* Umožňuje mazat jednotlivé stránky bez nutnosti přepisovat celý blok dat. Tím snižuje opotřebení disku a&nbsp;zvyšuje životnost.  
**Nevýhody
+
* Zároveň se při mazání bloky pouze označí jako nevyužité, samotné smazání dat lze provést až později. To umožňuje rychlejší zápis dat (není třeba blok nejprve přečíst, pokud je označen jako smazaný, mazání dat provede řadič až později).
***delší jména souborů,
+
* Zapnutí TRIM viz: [[Nástroje pro práci s diskem#Funkce TRIM u SSD| Nástroje pro práci s diskem]].
***soubory velikosti až 2 GB.
+
* Zdroje: [https://www.digitalcitizen.life/simple-questions-what-trim-ssds-why-it-useful DigitalCitizen.life &rarr; What is SSD TRIM], [https://searchstorage.techtarget.com/definition/TRIM TechTarget.com &rarr; TRIM]
***Velké disky pouze za cenu vyšší velikosti clusteru.
+
***Zastaralý
+
****Princip zůstává stejný jako u FAT16.
+
***Náchylný k chybám
+
****nemá žurnálování
+
**Výhody
+
***široká podpora
+
****HW zařízení
+
****operační systémy
+
***jednoduchý na implementaci
+
***nemá žurnálování
+
* exFAT
+
**jen Microsoft
+
**rozšiřuje FAT32
+
**odstraňuje omezení velikosti souboru
+
**zřejmě může podporovat žurnálování, pokud to povolíme
+
  
=== btrfs ===
 
*Subvoluming
 
**Například btrfs
 
**FS může být přes více fyzických zařízení
 
***prostor (raw storage) rozdělen na úseky (např. 1GB)
 
**nahrazuje LVM (Logical Volume Manager) a ZFS
 
**Při startu default subvolume
 
*Snapshots
 
**subvolume storing data of other
 
**Příkaz pro vytvoření:
 
***btrfs subvolume snapshot root root_snapshot_2011_01_11
 
**Obnovení
 
***# mount /media/btrfs# umount /home# mount -o defaults,subvol=home_snapshot_A /dev/sda /home# btrfs subvolume delete /media/btrfs/home****  # optional# umount /media/btrfs
 
*Copy on write
 
=== ext2/ext3/ext4 ===
 
*Vzájemně kompatibilní.
 
*ext3
 
**en.wikipedia.org > Wiki > Ext3 <http://en.wikipedia.org/wiki/Ext3>
 
**+
 
***zpětně kompatibilní s ext2
 
***žurnálování <#Freemind_Link_343852720>
 
****defaultně struktury, jsou potvrzeny (commit) až po dokončení zápisu dat
 
****může být narušeno užitím cache v disku
 
***Podporuje POSIX ACL
 
****Access Control Lists
 
**-
 
***není klasická defragmentace <#_Freemind_Link_1286303196>
 
***fsck jen v režimu read-only
 
***není transparentní komprese
 
*ext4
 
**dnes nativní pro běžné uživatelské distribuce Linuxu
 
*BTRFS
 
**<https://btrfs.wiki.kernel.org/index.php/Main_Page>
 
**Historie
 
***vyvinut firmou Oracle
 
***dnes GPL
 
**default pro Fedora 16 či 17
 
***fedoraproject.org > Wiki > Features > F16BtrfsDefaultFs <http://fedoraproject.org/wiki/Features/F16BtrfsDefaultFs>
 
**teprve se chystá podpora kontroly a opravy
 
**Vlastnosti:
 
***Velikost souboru až 2^64 B ~ 16 EiB
 
***Dynamic i-node allocation
 
***podpora svazků (volumes) a RAID
 
****vestavěná ve FS
 
****RAID 0, 1 a 10
 
****chystá se RAID 5 a 6
 
***kontrolní součty (checksumming)
 
***body obnovení (snapshotting
 
****uchová stav systému před ryzikovou operací
 
***On-line defragmentation
 
  
=== HFS+ ===
+
== Související stránky ==
*MacOS X
+
* [[Rozdělení disku]], [[Defragmentace]], [[Příklady souborových systémů]], [[Nástroje pro práci s diskem]]
*počítače Apple
+
=== swap ===
+
*Pro odkládání nepotřebných paměťových bloků na disk.
+
*Pod Windows se řeší speciálním souborem.
+
=== proc ===
+
*Pouze virtuální FS.
+
*Slouží k práci s procesy.
+

Aktuální verze z 19. 11. 2020, 20:31


Obsah

Souborový systém

K čemu je souborový systém?
Na disk tedy ukládáme
Souborový systém

Souborový systém (FS) je:

  1. formát zápisu metadat („Používám souborový systém ext3.“)
  2. označení pro konkrétní metadata na disku („Došlo k poškození souborového systému.“)


Formátování disku


Cluster

Vliv velikosti clusteru na výkon FS

Žurnálování

Princip
Co když dojde k přerušení operace uprosřed (například při havárii počítače)?
Poznámky
  • Funkce žurnálování může být narušeno užitím cache v disku. (Disk nahlásí dokončení operace, ale data jsou jen v cache, nikoli fyzicky zapsána na disk. Při havárii počítače se tedy data ztratí, ačkoli v žurnálu jsou vedeny jako dokončené.)
  • Žurnálování nevyřeší ztrátu dat, která se nestihla zapisat na pevný disk! Nicméně zajišťuje, že nedojde k porušení souborového systému (metadat).

Další vlastnosti FS


Typy souborových systémů

Související pojmy

LVM

RAID

Režimy: RAID 0, RAID 1, RAID 5,...

TRIM


Související stránky

Osobní nástroje
Jmenné prostory
Varianty
Akce
Výuka
Navigace
Nástroje