Souborové systémy

Z MiS
(Rozdíly mezi verzemi)
Přejít na: navigace, hledání
(Žurnálování: Opravena definice)
(Žurnálování: Upřesněn popis žurnálu a žurnálování.)
 
(Není zobrazeno 17 mezilehlých verzí od 1 uživatele.)
Řádka 1: Řádka 1:
 
[[Category:VSE]][[Category:Informatika]][[Category:OSY]][[Category:Ukládání_dat]]
 
[[Category:VSE]][[Category:Informatika]][[Category:OSY]][[Category:Ukládání_dat]]
 +
 
== Souborový systém ==
 
== Souborový systém ==
; Na disk ukládáme:
+
; K čemu je souborový systém?
* data souborů
+
* Pevný disk z pohledu HW je pouze dlouhá posloupnost stejně velkých sektorů, do kterých můžeme zapsat data.
* ''metadata''
+
* 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.
** pomocné informace, pomocí kterých data vyhledáváme
+
* Kromě samotných dat tedy musíme ukládat i pomocné informace.
** vlastník souboru, název souboru, velikost, práva,...
+
 
 +
; Na disk tedy ukládáme:
 +
* data (obsah souborů, to, co uživatel chce uložit)
 +
* ''metadata'' (pomocné informace)
 +
** ke kterému souboru daný kousek dat patří
 +
** informace pro vyhledávání: umístění ve složkách, názvy souborů,...
 +
** informace pro zabezpečení: vlastník souboru, práva pro přístup,...
 +
** další pomocné informace
  
 
; Souborový systém
 
; Souborový systém
Řádka 14: Řádka 22:
 
</div>
 
</div>
  
== Pojmy FS ==
+
 
; Cluster
+
== Formátování disku ==
*Základní součást datové oblasti logického disku.
+
* Vytváření souborového systému na logickém oddílu se označuje slovem ''formátování disku''.
*Nejmenší počet sektorů, které mohou tvořit soubor.
+
 
*Vliv velikosti clusteru na výkon FS
+
 
*Velikost nastavujeme při formátování.
+
== Cluster ==
*Pro celý souborový systém musí být jednotná velikost.
+
* 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í ==
 
== Ž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.
 
* 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
 
; Princip
 
* Když chci provádět diskovou operaci (mazat soubor, měnit nebo vytvářet soubor, vytvářet složku,...), pak:
 
* 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.
+
*# Nejprve do žurnálu zapíši, co budu provádět.
*# Pak provádím diskovou operaci.
+
*# Pak provedu diskovou operaci.
*# Pokud se operace dokončí v pořádku, potvrdím ji v žurnálu (commit).
+
*# 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?
+
; Co když dojde k přerušení operace uprosřed (například při havárii počítače)?
* Při dalším spuštění najdeme v žurnálu nepotvrzené operace.
+
* 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 musíme odvolat. (Některé možná půjdou i dokončit.)
+
* 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">
 
<div class="Poznamka">
 
; Poznámky
 
; 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.)
+
* 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.
+
* Ž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>
 
</div>
  
Řádka 47: Řádka 69:
 
* možnost vytváření snímků (image),
 
* možnost 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
+
**fdfs
+
 
+
== Příklady (diskových) FS: ==
+
=== NTFS ===
+
*šifrování, komprese
+
*menší clustery než u FAT32
+
*názvy souborů v UTF8
+
 
+
=== FAT/FAT32/exFAT ===
+
*Pochází z MS-DOSu resp. Windows.
+
*Dnes na disketách a paměťových kartách
+
*FAT32
+
**Nevýhody
+
***delší jména souborů,
+
***soubory velikosti až 2 GB.
+
***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 ===
+
== Související pojmy ==
* Pokročilý souborový systém pro GNU/Linux, Solaris,...
+
* Subvoluming
+
** Jeden FS může být rozprostřen přes více fyzických zařízení.
+
** Prostor (raw storage) rozdělen na úseky (např. 1GB), které se pak spojují do subvolumes.
+
** Nahrazuje LVM (Logical Volume Manager) a ZFS.
+
* Snapshots (snímky disku)
+
** Ukládání současného stavu disku a změn oproti tomuto stavu.
+
* Copy on write
+
** Vytváření kopie svazku při současné práci se svazkem.
+
  
=== ext2/ext3/ext4 ===
+
=== LVM ===
*Vzájemně kompatibilní.
+
* Systém pro správu logických oblastí.
*ext3
+
* Dělá mezivrstvu mezi operačním systémem a fyzickým rozdělením disku (MBR, GPT,...).
**en.wikipedia.org > Wiki > Ext3 <http://en.wikipedia.org/wiki/Ext3>
+
* Umožňuje snadno měnit velikosti logických svazků, zálohovat logické svazky, simulovat RAID atd.
**+
+
***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+ ===
+
=== RAID ===
*MacOS X
+
* Využití více fyzických disků pro redundantní ukládání dat.
*počítače Apple
+
* Při výpadku jednoho disku nepřijdu o data, data jdou dopočítat z informací na ostatních discích.
=== swap ===
+
* Nicméně nemohu využít celý součet kapacit všech disků, část celkové kapacity je využita pro kontrolní součty.
*Pro odkládání nepotřebných paměťových bloků na disk.
+
Režimy: RAID 0, RAID 1, RAID 5,...
*Pod Windows se řeší speciálním souborem.
+
=== proc ===
+
*Pouze virtuální FS.
+
*Slouží k práci s procesy.
+
  
 +
=== TRIM ===
 +
* 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í).
 +
* 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í).
 +
* 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.
 +
* 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).
 +
* Zapnutí TRIM viz: [[Nástroje pro práci s diskem#Funkce TRIM u SSD| Nástroje pro práci s diskem]].
 +
* 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]
  
  
 
== Související stránky ==
 
== Související stránky ==
* [[Rozdělení disku]]
+
* [[Rozdělení disku]], [[Defragmentace]], [[Příklady souborových systémů]], [[Nástroje pro práci s diskem]]

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