Souborové systémy

Z MiS
(Rozdíly mezi verzemi)
Přejít na: navigace, hledání
m (Přidána kategorie Ukládání dat)
(Žurnálování: Upřesněn popis žurnálu a žurnálování.)
 
(Není zobrazeno 20 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]]
== 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.
+
=== Žurnálování ===
+
*defaultně struktury, jsou potvrzeny (commit) až po dokončení zápisu dat
+
*může být narušeno užitím cache v disku
+
*Princip:
+
**Chci provádět diskovou operaci
+
***mazat soubor
+
***vytvářet soubor
+
***vytvářet složku
+
***...
+
**Postup akcí:
+
***Nejprve do žurnálu zapíši, co budu provádět.
+
***Pak provádím diskovou operaci.
+
***Pokud se operace dokončí v pořádku, potvrdím ji v žurnálu.
+
**Co když dojde k problému?
+
***Právě prováděnou operaci musím odvolat.
+
*Neřeší ztrátu dat, která se zapisovala!
+
**Zajišťuje, že nedojde k porušení souborového systému.
+
  
=== Další vlastnosti ===
+
; Na disk tedy ukládáme:
*vytváření snímků (image)
+
* 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
  
== Typy souborových systémů ==
+
; Souborový systém
*diskové
+
<div class="Definice">
*síťové
+
Souborový systém (FS) je:
**nfs
+
# formát zápisu metadat (''„Používám souborový systém ext3.“'')
**smb
+
# označení pro konkrétní metadata na disku (''„Došlo k poškození souborového systému.“)
*paměťové
+
</div>
**tmpfs
+
*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 ===
+
== Formátování disku ==
*Pochází z MS-DOSu resp. Windows.
+
* Vytváření souborového systému na logickém oddílu se označuje slovem ''formátování disku''.
*Dnes na disketách a paměťových kartách
+
 
*FAT32
+
 
**Nevýhody
+
== Cluster ==
***delší jména souborů,
+
* Podle konkrétního souborového systému se označuje ''cluster'', ''datový blok'' či ''alokační jednotka''.
***soubory velikosti až 2 GB.
+
* Základní jednotka pro zápis dat do datové oblasti logického disku.
***Velké disky pouze za cenu vyšší velikosti clusteru.
+
* Každý soubor zabírá vždy minimálně jeden cluster. Jeden cluster může zabírat jeden nebo více sektorů.
***Zastaralý
+
* Všechny clustery jsou stejně veliké, velikost nastavujeme při formátování.
****Princip zůstává stejný jako u FAT16.
+
* Pro celý souborový systém musí být jednotná velikost.
***Náchylný k chybám
+
* 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ý.)
****nemá žurnálování
+
 
**Výhody
+
; Vliv velikosti clusteru na výkon FS
***široká podpora
+
* menší clustery: nižší [[Defragmentace#Vnit.C5.99n.C3.AD_.C3.97_vn.C4.9Bj.C5.A1.C3.AD_fragmentace|vnitřní fragmentace'']].
****HW zařízení
+
* větší clustery:
****operační systémy
+
*# pokud mám na disku velké soubory, je třeba provést méně dílčích čtení pro načtení velkého souborů.
***jednoduchý na implementaci
+
*# 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]]
***nemá žurnálování
+
 
* exFAT
+
== Žurnálování ==
**jen Microsoft
+
* 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.
**rozšiřuje FAT32
+
* 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.)
**odstraňuje omezení velikosti souboru
+
 
**zřejmě může podporovat žurnálování, pokud to povolíme
+
; 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),
 +
* ...
 +
 
 +
 
 +
== Typy souborových systémů ==
 +
* Diskové
 +
** Běžně známé FS: NTFS, ext2/ext3/ext4, FAT32, btrfs,...
 +
** Viz [[Příklady souborových systémů]].
 +
* Síťové (NFS, SMB,...)
 +
* Paměťové (<tt>tmpfs</tt>)
 +
* Virtuální (<tt>procfs</tt> &mdash; viz [[Adresář /proc| adresář <tt>/proc</tt>]], <tt>fdfs</tt>)
  
=== 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