Btrfs: differenze tra le versioni
Wtf (discussione | contributi) |
Wtf (discussione | contributi) |
||
(64 versioni intermedie di uno stesso utente non sono mostrate) | |||
Riga 2: | Riga 2: | ||
|precedente=RAID:_Redundant_Array_of_Indipendent_Disks | |precedente=RAID:_Redundant_Array_of_Indipendent_Disks | ||
|successivo=Nfs-kernel-server:_condividere_risorse_tra_macchine_GNU/Linux | |successivo=Nfs-kernel-server:_condividere_risorse_tra_macchine_GNU/Linux | ||
}}{{Versioni_compatibili}} | }}{{Versioni_compatibili|Bookworm}} | ||
== Introduzione == | == Introduzione == | ||
Dall'[https://en.wikipedia.org/wiki/Btrfs omonima pagina] di | Dall'[https://en.wikipedia.org/wiki/Btrfs omonima pagina] di Wikipedia inglese: | ||
<blockquote> | <blockquote> | ||
Btrfs (pronounced as "better F S", "butter F S", "b-tree F S", or B.T.R.F.S.) is a computer storage format that combines a file system based on the copy-on-write (COW) principle with a logical volume manager (distinct from Linux's LVM), developed together.<br/> | Btrfs (pronounced as "better F S", "butter F S", "b-tree F S", or B.T.R.F.S.) is a computer storage format that combines a file system based on the copy-on-write (COW) principle with a logical volume manager (distinct from Linux's LVM), developed together.<br/> | ||
Riga 14: | Riga 14: | ||
* possibilità di creare volumi dati in modo simile ad [[LVM: Logical Volume Manager | LVM]] e quindi possibilità di variare facilmente le dimensioni di una "partizione"; | * possibilità di creare volumi dati in modo simile ad [[LVM: Logical Volume Manager | LVM]] e quindi possibilità di variare facilmente le dimensioni di una "partizione"; | ||
* possibilità di avere ridondanza dei dati in modo simile al [[RAID: Redundant Array of Indipendent Disks | RAID]] 1. | * possibilità di avere ridondanza dei dati in modo simile al [[RAID: Redundant Array of Indipendent Disks | RAID]] 1. | ||
''Btrfs'' è funzionalmente simile al ben più famoso ZFS, ma a differenza di quest'ultimo beneficia di un'integrazione nel kernel di linux. | * ''Copy On Write'' (COW), che riduce grandemente i problemi legati all'interruzione improvvisa dei processi di scrittura dati (es. quando salta la corrente) e inoltre permette di creare ''istantanee'' del filesystem o di una parte di esso (es. ''subvolume''). | ||
''Btrfs'' è funzionalmente simile al ben più famoso ''ZFS'', ma a differenza di quest'ultimo beneficia di un'integrazione nel kernel di linux. | |||
{{Warningbox|Per quanto ''btrfs'' sia stato inserito nel kernel di linux da più di 15 anni esistono ancora configurazioni/funzionalità che sono da considerarsi sperimentali o addirittura problematiche, per tanto si consiglia caldamente di leggere [https://wiki.debian.org/Btrfs questa pagina] del wiki di debian per maggiori informazioni sull'argomento.}} | {{Warningbox|Per quanto ''btrfs'' sia stato inserito nel kernel di linux da più di 15 anni esistono ancora configurazioni/funzionalità che sono da considerarsi sperimentali o addirittura problematiche, per tanto si consiglia caldamente di leggere [https://wiki.debian.org/Btrfs questa pagina] del wiki di debian per maggiori informazioni sull'argomento.}} | ||
{{Box|Volumi, dischi e partizioni|Nel seguito della guida si scriverà sempre genericamente di volume a prescindere che questo sia composto da un solo disco/partizione oppure più di uno. Dal punto di vista pratico infatti non fa alcuna differenza perché l'utente vedrà sempre e soltanto una "partizione" (ma lo spazio totale usabile ovviamente cambierà).}} | {{Box|Volumi, dischi e partizioni|Nel seguito della guida si scriverà sempre genericamente di volume a prescindere che questo sia composto da un solo disco/partizione oppure più di uno. Dal punto di vista pratico infatti non fa alcuna differenza perché l'utente vedrà sempre e soltanto una "partizione" (ma lo spazio totale usabile ovviamente cambierà).}} | ||
{{Suggerimento|Alcune operazioni (come la copia dei dati dai vecchi dischi/partizioni) possono richiedere molto tempo, pertanto si consiglia di eseguire dette operazioni all'interno di una sessione di [[GNU/Screen]] (o altro applicativo che permetta di "scollegarsi" dalla sessione di terminale senza terminarla).}} | |||
== Installazione == | == Installazione == | ||
Riga 25: | Riga 27: | ||
== Utilizzo == | == Utilizzo == | ||
{{Warningbox|<u>LASCIARE SEMPRE</u> almeno 10GB di spazio libero su ogni volume ''btrfs'' per permettere le operazioni di manutenzione.}} | |||
Per formattare una nuova partizione il comando generale è: | Per formattare una nuova partizione il comando generale è: | ||
<pre># mkfs.btrfs -L mia_etichetta /dev/sdX1</pre> | <pre># mkfs.btrfs -L mia_etichetta /dev/sdX1</pre> | ||
Riga 33: | Riga 36: | ||
* <code>-f</code> per forzare il sistema a formattare una partizione che non sia vuota, cioè che abbia già un suo filesystem. | * <code>-f</code> per forzare il sistema a formattare una partizione che non sia vuota, cioè che abbia già un suo filesystem. | ||
* <code>-d</code> per specificare il profilo dati da usare. Il valore predefinito è <code>single</code>. | * <code>-d</code> per specificare il profilo dati da usare. Il valore predefinito è <code>single</code>. | ||
* <code>-m</code> per specificare il profilo metadati da usare. Il valore predefinito è <code>dup</code> nel caso di disco singolo oppure <code>raid1</code> nel caso di | * <code>-m</code> per specificare il profilo metadati da usare. Il valore predefinito è <code>dup</code> nel caso di disco singolo oppure <code>raid1</code> nel caso di due o più. | ||
=== Profili (meta)dati === | === Profili (meta)dati === | ||
Per definire se si vuole ridondanza sia di dati che metadati si usano i profili, selezionabili come già scritto sopra con le opzioni rispettivamente <code>-d</code> e <code>-m</code>. La scelta dei profili e il loro significato è il medesimo sia per i dati che per i metadati, ovvero non esistono profili dedicati per i soli dati o metadati. | Per definire se si vuole ridondanza sia di dati che metadati si usano i profili, selezionabili come già scritto sopra con le opzioni rispettivamente <code>-d</code> e <code>-m</code>. La scelta dei profili e il loro significato è il medesimo sia per i dati che per i metadati, ovvero non esistono profili dedicati per i soli dati o metadati. | ||
{{Suggerimento|Nel caso di disco singolo non c'è alcuna ragione di scegliere un profilo metadati diverso da quello predefinito.}} | {{Suggerimento|Nel caso di disco singolo non c'è di norma alcuna ragione di scegliere un profilo metadati diverso da quello predefinito.}} | ||
* <code>single</code>: implica nessuna ridondanza dei (meta)dati e quindi permette di sfruttare il 100% dello spazio disponibile di un volume. Nel caso di più dischi/partizioni lo spazio totale disponibile sarà semplicemente la somma dei dischi/partizioni che lo compongono. | * <code>single</code>: implica nessuna ridondanza dei (meta)dati e quindi permette di sfruttare il 100% dello spazio disponibile di un volume. Nel caso di più dischi/partizioni lo spazio totale disponibile sarà semplicemente la somma dei dischi/partizioni che lo compongono. | ||
* <code>dup</code>: da usare nel solo caso di volume composto da disco/partizione singolo, implica appunto la duplicazione dei (meta)dati. Nel caso dei dati lo spazio totale disponibile sarà quindi la metà di quello teorico (la duplicazione dei metadati invece comporta un consumo di spazio molto meno rilevante). Questo profilo protegge contro il degrado del tempo, ma non contro eventuali guasti hardware. | * <code>dup</code>: da usare nel solo caso di volume composto da disco/partizione singolo, implica appunto la duplicazione dei (meta)dati. Nel caso dei dati lo spazio totale disponibile sarà quindi la metà di quello teorico (la duplicazione dei metadati invece comporta un consumo di spazio molto meno rilevante). Questo profilo protegge contro il degrado del tempo, ma non contro eventuali guasti hardware. | ||
{{Cautionbox|Nel caso di disco singolo se si sceglie profilo <code>single</code> per i dati e <code>dup</code> per i metadati si sarà solo informati di un eventuale danneggiamento dei dati, ma non sarà possibile una riparazione degli stessi. L'unico modo per proteggere i dati in questo caso è scegliere il profilo <code>dup</code> sia per i dati che metadati.}} | {{Cautionbox|Nel caso di disco singolo se si sceglie profilo <code>single</code> per i dati e <code>dup</code> per i metadati si sarà solo informati di un eventuale danneggiamento dei dati, ma non sarà possibile una riparazione degli stessi. L'unico modo per proteggere i dati in questo caso è scegliere il profilo <code>dup</code> sia per i dati che metadati.}} | ||
* <code>raid1</code>: da usare solo nel caso di volume composto da due o più dischi/partizioni. Funziona in modo simile al raid1 di [[RAID: Redundant Array of Indipendent Disks | mdadm]], ma con due differenze importanti | * <code>raid1</code>: da usare solo nel caso di volume composto da due o più dischi/partizioni. Funziona in modo simile al raid1 di [[RAID: Redundant Array of Indipendent Disks | mdadm]], ma con due differenze importanti | ||
:* lo spazio totale disponibile è sempre | :* lo spazio totale disponibile è sempre <code>(somma dei dischi/partizioni che compongono il volume)/'''2'''</code>, e non <code>(somma dei dischi/partizioni che compongono il volume)/'''N'''</code> (con N = n. totale dischi/partizioni); | ||
:* i dischi/partizioni che compongono il volume non devono necessariamente avere la stesse dimensioni, ma la capacità di nessuno di essi può essere superiore alla somma delle capacità di tutti gli altri, ad esempio nel caso di tre dischi sarebbe accettabile avere 4TB, 3TB e 1TB, ma non 6TB e 2x1TB | :* i dischi/partizioni che compongono il volume non devono necessariamente avere la stesse dimensioni, ma la capacità di nessuno di essi può essere superiore alla somma delle capacità di tutti gli altri, ad esempio nel caso di tre dischi sarebbe accettabile avere 4TB, 3TB e 1TB, ma non 6TB e 2x1TB. | ||
: Quando il volume è composto da due dischi/partizioni di dimensioni identiche allora si ha in pratica coincidenza con un volume raid 1 classico composto da due dischi. | : Quando il volume è composto da due dischi/partizioni di dimensioni identiche allora si ha in pratica coincidenza con un volume raid 1 classico composto da due dischi. | ||
{{Suggerimento|È consigliato avere dischi/partizioni di pari dimensioni.}} | |||
* <code>raid1c3, raid1c4</code>: ancora poco testati e quindi sconsigliati, sono inclusi al solo scopo di chiarire meglio le differenze tra il raid di ''btrfs'' e quello classico. Entrambi i profili richiedono che il volume sia composto da almeno tre e quattro dischi/partizioni rispettivamente. Il primo crea tre copie dei (meta)dati e il secondo quattro, ergo lo spazio totale disponibile sarà rispettivamente 1/3 ed 1/4 della somma teorica totale. Questi due profili funzionano esattamente come quello di <code>raid1</code>, eccetto appunto il numero di copie, inoltre quando i volumi sono composti rispettivamente da 3 e 4 dischi/partizioni di dimensioni identiche coincidono a livello pratico con un volume raid 1 classico composto dallo stesso numero di dischi. | * <code>raid1c3, raid1c4</code>: ancora poco testati e quindi sconsigliati, sono inclusi al solo scopo di chiarire meglio le differenze tra il raid di ''btrfs'' e quello classico. Entrambi i profili richiedono che il volume sia composto da almeno tre e quattro dischi/partizioni rispettivamente. Il primo crea tre copie dei (meta)dati e il secondo quattro, ergo lo spazio totale disponibile sarà rispettivamente 1/3 ed 1/4 della somma teorica totale. Questi due profili funzionano esattamente come quello di <code>raid1</code>, eccetto appunto il numero di copie, inoltre quando i volumi sono composti rispettivamente da 3 e 4 dischi/partizioni di dimensioni identiche coincidono a livello pratico con un volume raid 1 classico composto dallo stesso numero di dischi. | ||
=== Spazio libero/occupato === | |||
Per sapere quant'è lo spazio libero e/o occupato si consiglia l'uso di | |||
<pre>btrfs filesystem usage -T /punto/di/mount/desiderato/</pre> | |||
invece del solito <code>df</code> poiché querst'ultimo quando utilizzato su volumi ''btrfs'' potrebbe potenzialmente restituire valori significativamente diversi dal vero.<br/> | |||
Altri comandi utili in tal senso sono <code>btrfs filesystem show</code> e <code>btrfs device usage</code>. | |||
=== Manutenzione volumi === | |||
{{Suggerimento|Leggere attentamente sia [https://manpages.debian.org/bookworm/btrfsmaintenance/btrfsmaintenance.8.en.html il manuale di btrfsmaintenance] che il documento <code>/usr/share/doc/btrfsmaintenance/README.Debian</code>.}} | |||
Al momento l'unico script raccomandato è quello per l'esecuzione delle operazioni di ''scrub'', lasciare quindi disattivati gli altri.<br/> | |||
La configurazione base di questo strumento considera come volume predefinito da controllare la radice, cioè <code>/</code>, se però questo non è il vostro caso allora è necessario | |||
* editare il file <code>/etc/default/btrfsmaintenance</code> | |||
* cercare la riga contenente il parametro <code>BTRFS_SCRUB_MOUNTPOINTS</code> e modificare il valore predefinito col punto di mount del proprio volume (è possibile specificare più percorsi separandoli con il carattere <code>:</code>). | |||
Fatto ciò è necessario aggiungere a ''CRON'' gli script relativi alle operazioni che sono state attivate, quindi digitare | |||
<pre># /usr/share/btrfsmaintenance/btrfsmaintenance-refresh-cron.sh</pre> | |||
{{Warningbox|Questo script deve essere eseguito ogni volta che si apportano modifiche a <code>/etc/default/btrfsmaintenance</code>.}} | |||
Se per esempio si è attivato come consigliato il solo script di ''scrub'' e non si è cambiata la frequenza allora digitando | |||
<pre>ls -hl /etc/cron*</pre> | |||
lo script dovrebbe comparire in <code>/etc/cron.monthly</code>, ovvero tra le varie informazioni stampate a video si dovrebbe vedere qualcosa di simile a | |||
<pre> | |||
/etc/cron.monthly: | |||
totale 4,0K | |||
-rwxr-xr-x 1 root root 313 10 gen 2023 0anacron | |||
lrwxrwxrwx 1 root root 42 29 dic 19.04 btrfs-scrub -> /usr/share/btrfsmaintenance/btrfs-scrub.sh | |||
</pre> | |||
{{Box|Systemd|Stando a quanto scritto in <code>/usr/share/doc/btrfsmaintenance/README.Debian</code> dovrebbe essere possibile attivare gli script anche in <code>systemd</code>, ma al momento chi scrive non ci è riuscito.}} | |||
== Esempi == | == Esempi == | ||
=== Raid1 | === Disco/partizione singoli === | ||
Ipotesi | ==== ''single+dup'' ==== | ||
Si noti che questa configurazione '''NON OFFRE''': | |||
# la possibilità di correggere eventuali errori nei dati, ma solo la possibilità di verificare se gli stessi sono integri o meno; | |||
# ridondanza hardware; | |||
Posto quindi che la partizione da usare per il volume ''btrfs'' esista già e sia identificata da <code>/dev/sdX1</code> il comando da digitare per creare il volume è: | |||
{{Warningbox|Quest'operazione implica la cancellazione permanente di tutti i dati sulla partizione.}} | |||
<pre># mkfs.btrfs -f -L nome_etichetta -d single -m dup /dev/sdX1</pre> | |||
dove le opzioni <code>-d</code> e <code>-m</code> avrebbero potuto essere omesse poiché i valori specificati coincidono con quelli predefiniti. | |||
==== ''dup+dup'' ==== | |||
Questa casistica è simile al ''raid1'', infatti rispetto al caso precedente anche i dati vengono duplicati, ma sullo stesso disco. | |||
{{Cautionbox|Con questa configurazione lo spazio totale realmente disponibile sarà la metà di quello teorico e '''NON''' viene fornita ridondanza hardware.}} | |||
In sintesi rispetto al caso precedente questa configurazione permette anche la possibilità di correggere eventuali errori nei dati, non solo di verificarne l'integrità.<br/> | |||
Posto quindi che la partizione da usare per il volume ''btrfs'' esista già e sia identificata da <code>/dev/sdX1</code> il comando da digitare per creare il volume è: | |||
{{Warningbox|Quest'operazione implica la cancellazione permanente di tutti i dati sulla partizione.}} | |||
<pre># mkfs.btrfs -f -L nome_etichetta -d dup -m dup /dev/sdX1</pre> | |||
dove l'opzione <code>-m</code> avrebbe potuto essere omessa poiché il valore specificato coincide con quello predefinito. | |||
=== Raid1 dati e metadati, sei dischi === | |||
'''Ipotesi''' | |||
* si hanno a disposizione sei dischi a due a due di identiche dimensioni e precisamente pari rispettivamente a 3TB, 2TB ed 1,5TB; | * si hanno a disposizione sei dischi a due a due di identiche dimensioni e precisamente pari rispettivamente a 3TB, 2TB ed 1,5TB; | ||
* i dischi siano identificati come <code>/dev/sdU</code> (3TB), <code>/dev/sdV</code> ( | * i dischi siano identificati come <code>/dev/sdU</code> (3TB), <code>/dev/sdV</code> (2TB), <code>/dev/sdW</code> (1,5TB), <code>/dev/sdX</code> (3TB), <code>/dev/sdY</code> (2TB), <code>/dev/sdZ</code> (1,5TB); | ||
* i dischi non sono nuovi e contengono dati; | * i dischi non sono nuovi e contengono dati; | ||
* ciascun disco contiene gli stessi dati dell'altro avente pari dimensioni, ad es. il i due dischi da 3TB contengono ciascuno una copia degli stessi dati; | * ciascun disco contiene gli stessi dati dell'altro avente pari dimensioni, ad es. il i due dischi da 3TB contengono ciascuno una copia degli stessi dati; | ||
'''Obiettivo'''<br/> | |||
Creare un volume ''btrfs raid1'' da 6,5TB di spazio totale composto da tutti e sei i dischi, ma senza dover necessariamente copiare prima i dati già presenti altrove. | |||
{{Cautionbox|Si consiglia caldamente di fare una copia di backup dei dati presenti sui dischi che andranno a comporre il volume ''btrfs'' prima di iniziare le operazioni.}} | |||
'''Passo 1'''<br/> | |||
Selezionare tre dischi tutti di differente capacità e pulirli | |||
{{Warningbox|Quest'operazione implica la cancellazione permanente di tutti i dati dai dischi puliti.}} | |||
<pre># wipefs -a /dev/sdU /dev/sdV /dev/sdW</pre> | <pre># wipefs -a /dev/sdU /dev/sdV /dev/sdW</pre> | ||
'''Passo 2'''<br/> | |||
Ripartizionare i tre dischi | |||
<pre> | <pre> | ||
# parted /dev/sdU mklabel gpt mkpart nome_desiderato1 btrfs 0% 100% | # parted /dev/sdU mklabel gpt mkpart nome_desiderato1 btrfs 0% 100% | ||
Riga 65: | Riga 122: | ||
# parted /dev/sdW mklabel gpt mkpart nome_desiderato3 btrfs 0% 100% | # parted /dev/sdW mklabel gpt mkpart nome_desiderato3 btrfs 0% 100% | ||
</pre> | </pre> | ||
'''Passo 3'''<br/> | |||
Formattare i 3 dischi e contestualmente creare il volume ''btrfs'' | |||
<pre># mkfs.btrfs -f -L nome_etichetta -d single -m raid1 /dev/sdU1 /dev/sdV1 /dev/sdW1</pre> | |||
A questo punto digitando il comando <code># lsblk -f</code> si vedrà che l'UUID di tutte e tre le partizioni è il medesimo. | |||
'''Passo 4'''<br/> | |||
Montare il volume btrfs appena creato o specificando il primo disco dei tre o l'UUID (visibile tramite <code>lsblk -f</code> per esempio) del volume ''btrfs'': | |||
<pre># mount /dev/sdU1 /punto/di/mount/desiderato/</pre> | <pre># mount /dev/sdU1 /punto/di/mount/desiderato/</pre> | ||
'''Passo 5'''<br/> | |||
Copiare tutti i dati dai dischi <code>/dev/sdX /dev/sdY /dev/sdZ</code> sul nuovo volume ''btrfs''. | |||
{{Cautionbox|Se i dati da copiare sono molti, ad esempio qualche TB, l'operazione potrebbe richiedere anche uno o più giorni.}} | |||
'''Passo 6'''<br/> | |||
Pulire anche i tre dischi rimanenti. | |||
{{Warningbox|Quest'operazione implica la cancellazione permanente di tutti i dati dai dischi puliti.}} | |||
<pre># wipefs -a /dev/sdX /dev/sdY /dev/sdZ</pre> | |||
'''Passo 7'''<br/> | |||
Ripartizionare anche i tre dischi rimanenti | |||
<pre> | |||
# parted /dev/sdX mklabel gpt mkpart nome_desiderato4 btrfs 0% 100% | |||
# parted /dev/sdY mklabel gpt mkpart nome_desiderato5 btrfs 0% 100% | |||
# parted /dev/sdZ mklabel gpt mkpart nome_desiderato6 btrfs 0% 100% | |||
</pre> | |||
'''Passo 8'''<br/> | |||
Aggiungere i tre dischi appena puliti al nostro volume ''btfrs'' (che <u>DEVE</u> essere montato) | |||
<pre># btrfs device add -f /dev/sdX1 /dev/sdY1 /dev/sdZ1 /punto/di/mount/desiderato/</pre> | |||
'''Passo 9'''<br/> | |||
Convertire i dati del volume ''btrfs'' da <code>single</code> a <code>raid1</code>. | |||
{{Cautionbox|Se i dati da copiare sono molti, ad esempio qualche TB, l'operazione potrebbe richiedere anche uno o più giorni.}} | |||
<pre># btrfs balance start -v -dconvert=raid1 /punto/di/mount/desiderato/</pre> | |||
Qualora inizialmente non si fosse scelto il profilo <code>raid1</code> per i metadati sarebbe possibile convertire al volo anche gli stessi semplicemente aggiungendo l'opzione <code>-mconvert=raid1</code> al precedente comando. | |||
'''Passo 10'''<br/> | |||
Al termine dell'operazione di bilanciamento verrà stampato a video | |||
<pre>Done, had to relocate ABC out of DEF chunks</pre> | |||
e il prompt del terminale sarà di nuovo usabile.<br/> | |||
Il volume è ora pronto e il suo stato può essere indagato con tre comandi di cui il primo è: | |||
<pre># btrfs filesystem show /punto/di/mount/desiderato/</pre> | |||
che restituirà una sintesi simile a | |||
<pre> | |||
Label: 'nome_etichetta' uuid: ABCDEFGH-... | |||
Total devices 6 FS bytes used 4.05TiB | |||
devid 1 size 1.82TiB used 1.23TiB path /dev/sdV1 | |||
devid 2 size 2.73TiB used 1.96TiB path /dev/sdU1 | |||
devid 3 size 1.36TiB used 793.01GiB path /dev/sdW1 | |||
devid 4 size 1.82TiB used 1.23TiB path /dev/sdY1 | |||
devid 5 size 2.73TiB used 2.14TiB path /dev/sdX1 | |||
devid 6 size 1.36TiB used 793.00GiB path /dev/sdZ1 | |||
</pre> | |||
Il secondo comando è invece | |||
<pre># btrfs filesystem usage -T /punto/di/mount/desiderato/</pre> | |||
e stamperà a video qualcosa di simile a: | |||
<pre> | |||
Overall: | |||
Device size: 11.83TiB | |||
Device allocated: 8.10TiB | |||
Device unallocated: 3.72TiB | |||
Device missing: 0.00B | |||
Device slack: 0.00B | |||
Used: 8.09TiB | |||
Free (estimated): 1.87TiB (min: 1.87TiB) | |||
Free (statfs, df): 1.77TiB | |||
Data ratio: 2.00 | |||
Metadata ratio: 2.00 | |||
Global reserve: 512.00MiB (used: 0.00B) | |||
Multiple profiles: no | |||
Data Metadata System | |||
Id Path RAID1 RAID1 RAID1 Unallocated Total Slack | |||
-- --------- --------- -------- --------- ----------- -------- ----- | |||
1 /dev/sdV1 1.22TiB 5.00GiB - 605.02GiB 1.82TiB - | |||
2 /dev/sdU1 1.95TiB 6.00GiB 8.00MiB 790.51GiB 2.73TiB - | |||
3 /dev/sdW1 792.00GiB 1.00GiB 8.00MiB 604.26GiB 1.36TiB - | |||
4 /dev/sdY1 1.23TiB - - 605.02GiB 1.82TiB - | |||
5 /dev/sdX1 2.14TiB - - 604.52GiB 2.73TiB - | |||
6 /dev/sdZ1 793.00GiB - - 604.26GiB 1.36TiB - | |||
-- --------- --------- -------- --------- ----------- -------- ----- | |||
Total 4.04TiB 6.00GiB 8.00MiB 3.72TiB 11.83TiB 0.00B | |||
Used 4.04TiB 4.36GiB 608.00KiB | |||
</pre> | |||
Infine il terzo è | |||
<pre># btrfs device usage /punto/di/mount/desiderato/</pre> | |||
che resituirà qualcosa di simile a: | |||
<pre> | |||
/dev/sdV1, ID: 1 | |||
Device size: 1.82TiB | |||
Device slack: 0.00B | |||
Data,RAID1: 1.22TiB | |||
Metadata,RAID1: 5.00GiB | |||
Unallocated: 605.02GiB | |||
/dev/sdU1, ID: 2 | |||
Device size: 2.73TiB | |||
Device slack: 0.00B | |||
Data,RAID1: 1.95TiB | |||
Metadata,RAID1: 6.00GiB | |||
System,RAID1: 8.00MiB | |||
Unallocated: 790.51GiB | |||
/dev/sdW1, ID: 3 | |||
Device size: 1.36TiB | |||
Device slack: 0.00B | |||
Data,RAID1: 792.00GiB | |||
Metadata,RAID1: 1.00GiB | |||
System,RAID1: 8.00MiB | |||
Unallocated: 604.26GiB | |||
/dev/sdY1, ID: 4 | |||
Device size: 1.82TiB | |||
Device slack: 0.00B | |||
Data,RAID1: 1.23TiB | |||
Unallocated: 605.02GiB | |||
/dev/sdX1, ID: 5 | |||
Device size: 2.73TiB | |||
Device slack: 0.00B | |||
Data,RAID1: 2.14TiB | |||
Unallocated: 604.52GiB | |||
/dev/sdZ1, ID: 6 | |||
Device size: 1.36TiB | |||
Device slack: 0.00B | |||
Data,RAID1: 793.00GiB | |||
Unallocated: 604.26GiB | |||
</pre> | |||
'''Passo 11'''<br/> | |||
Editare il file <code>/etc/default/btrfsmaintenance</code> sostituendo al valore predefinito di <code>BTRFS_SCRUB_MOUNTPOINTS</code> quello scelto (<code>/punto/di/mount/desiderato/</code> in questo esempio) e infine attivare i servizi <code>btrfsmaintenance-refresh.service</code> e <code>btrfs-scrub.timer</code> come descritto nell'apposita sezione di questa guida. | |||
== Approfondimenti == | |||
=== Manpages === | === Manpages === | ||
Riga 76: | Riga 262: | ||
* <code>man btrfs</code>, [https://manpages.debian.org/bookworm/btrfs-progs/btrfs.8.en.html HTML] | * <code>man btrfs</code>, [https://manpages.debian.org/bookworm/btrfs-progs/btrfs.8.en.html HTML] | ||
* <code>man mkfs.btrfs</code>, [https://manpages.debian.org/bookworm/btrfs-progs/mkfs.btrfs.8.en.html HTML] | * <code>man mkfs.btrfs</code>, [https://manpages.debian.org/bookworm/btrfs-progs/mkfs.btrfs.8.en.html HTML] | ||
* <code>man btrfsmaintenance</code>, [https://manpages.debian.org/bookworm/btrfsmaintenance/btrfsmaintenance.8.en.html HTML] | |||
=== Sitografia === | === Sitografia === | ||
* [https://btrfs.readthedocs.io/en/latest/index.html Documentazione ufficiale] | |||
* [https://wiki.debian.org/Btrfs Pagina wiki Debian] | * [https://wiki.debian.org/Btrfs Pagina wiki Debian] | ||
* [https://wiki.tnonline.net/w/Category:Btrfs Forza's ramblings btrfs wiki] | |||
* [https://en.wikipedia.org/wiki/Btrfs Btrfs], pagina inglese di wikipedia | * [https://en.wikipedia.org/wiki/Btrfs Btrfs], pagina inglese di wikipedia | ||
* [https://fedoramagazine.org/working-with-btrfs-general-concepts/ Articolo introduttivo] | |||
{{Autori | Autore = [[Utente:Wtf|Wtf]] ([[Discussioni utente:Wtf|discussioni]]) 17:58, 25 dic 2024 (UTC) }} | {{Autori | Autore = [[Utente:Wtf|Wtf]] ([[Discussioni utente:Wtf|discussioni]]) 17:58, 25 dic 2024 (UTC) }} |
Versione attuale delle 18:15, 29 dic 2024
|
Versioni Compatibili Debian 12 "bookworm" |
Introduzione
Dall'omonima pagina di Wikipedia inglese:
Btrfs (pronounced as "better F S", "butter F S", "b-tree F S", or B.T.R.F.S.) is a computer storage format that combines a file system based on the copy-on-write (COW) principle with a logical volume manager (distinct from Linux's LVM), developed together.
[...]
Btrfs is intended to address the lack of pooling, snapshots, checksums, and integral multi-device spanning in Linux file systems.
In poche parole questo filesystem incorpora alcune funzionalità avanzate come:
- controllo dell'integrità dei dati per rilevare ed eventualmente correggere automaticamente alterazioni dei dati dovuti per esempio al semplice scorrere del tempo (Data degradation);
- possibilità di creare volumi dati in modo simile ad LVM e quindi possibilità di variare facilmente le dimensioni di una "partizione";
- possibilità di avere ridondanza dei dati in modo simile al RAID 1.
- Copy On Write (COW), che riduce grandemente i problemi legati all'interruzione improvvisa dei processi di scrittura dati (es. quando salta la corrente) e inoltre permette di creare istantanee del filesystem o di una parte di esso (es. subvolume).
Btrfs è funzionalmente simile al ben più famoso ZFS, ma a differenza di quest'ultimo beneficia di un'integrazione nel kernel di linux.
ATTENZIONE Per quanto btrfs sia stato inserito nel kernel di linux da più di 15 anni esistono ancora configurazioni/funzionalità che sono da considerarsi sperimentali o addirittura problematiche, per tanto si consiglia caldamente di leggere questa pagina del wiki di debian per maggiori informazioni sull'argomento. |
Suggerimento Alcune operazioni (come la copia dei dati dai vecchi dischi/partizioni) possono richiedere molto tempo, pertanto si consiglia di eseguire dette operazioni all'interno di una sessione di GNU/Screen (o altro applicativo che permetta di "scollegarsi" dalla sessione di terminale senza terminarla). |
Installazione
Tutti gli strumenti necessari a creare e manipolare un filesystem btrfs sono contenuti in un solo pacchetto:
# apt install btrfs-progs
Si consiglia di installare anche un pacchetto per l'automazione della manutenzione dei volumi btrfs, che per la loro complessità sono soggetti nel tempo a degradazione delle prestazioni se non manutenuti:
# apt install btrfsmaintenance
Utilizzo
ATTENZIONE LASCIARE SEMPRE almeno 10GB di spazio libero su ogni volume btrfs per permettere le operazioni di manutenzione. |
Per formattare una nuova partizione il comando generale è:
# mkfs.btrfs -L mia_etichetta /dev/sdX1
dove
/dev/sdX1
è la partizione da formattare;-L
è l'opzione che permette di assegnare l'etichetta alla partizione da formattare.
Altre opzioni utili sono:
-f
per forzare il sistema a formattare una partizione che non sia vuota, cioè che abbia già un suo filesystem.-d
per specificare il profilo dati da usare. Il valore predefinito èsingle
.-m
per specificare il profilo metadati da usare. Il valore predefinito èdup
nel caso di disco singolo oppureraid1
nel caso di due o più.
Profili (meta)dati
Per definire se si vuole ridondanza sia di dati che metadati si usano i profili, selezionabili come già scritto sopra con le opzioni rispettivamente -d
e -m
. La scelta dei profili e il loro significato è il medesimo sia per i dati che per i metadati, ovvero non esistono profili dedicati per i soli dati o metadati.
Suggerimento Nel caso di disco singolo non c'è di norma alcuna ragione di scegliere un profilo metadati diverso da quello predefinito. |
single
: implica nessuna ridondanza dei (meta)dati e quindi permette di sfruttare il 100% dello spazio disponibile di un volume. Nel caso di più dischi/partizioni lo spazio totale disponibile sarà semplicemente la somma dei dischi/partizioni che lo compongono.dup
: da usare nel solo caso di volume composto da disco/partizione singolo, implica appunto la duplicazione dei (meta)dati. Nel caso dei dati lo spazio totale disponibile sarà quindi la metà di quello teorico (la duplicazione dei metadati invece comporta un consumo di spazio molto meno rilevante). Questo profilo protegge contro il degrado del tempo, ma non contro eventuali guasti hardware.
raid1
: da usare solo nel caso di volume composto da due o più dischi/partizioni. Funziona in modo simile al raid1 di mdadm, ma con due differenze importanti
- lo spazio totale disponibile è sempre
(somma dei dischi/partizioni che compongono il volume)/2
, e non(somma dei dischi/partizioni che compongono il volume)/N
(con N = n. totale dischi/partizioni); - i dischi/partizioni che compongono il volume non devono necessariamente avere la stesse dimensioni, ma la capacità di nessuno di essi può essere superiore alla somma delle capacità di tutti gli altri, ad esempio nel caso di tre dischi sarebbe accettabile avere 4TB, 3TB e 1TB, ma non 6TB e 2x1TB.
- lo spazio totale disponibile è sempre
- Quando il volume è composto da due dischi/partizioni di dimensioni identiche allora si ha in pratica coincidenza con un volume raid 1 classico composto da due dischi.
Suggerimento È consigliato avere dischi/partizioni di pari dimensioni. |
raid1c3, raid1c4
: ancora poco testati e quindi sconsigliati, sono inclusi al solo scopo di chiarire meglio le differenze tra il raid di btrfs e quello classico. Entrambi i profili richiedono che il volume sia composto da almeno tre e quattro dischi/partizioni rispettivamente. Il primo crea tre copie dei (meta)dati e il secondo quattro, ergo lo spazio totale disponibile sarà rispettivamente 1/3 ed 1/4 della somma teorica totale. Questi due profili funzionano esattamente come quello diraid1
, eccetto appunto il numero di copie, inoltre quando i volumi sono composti rispettivamente da 3 e 4 dischi/partizioni di dimensioni identiche coincidono a livello pratico con un volume raid 1 classico composto dallo stesso numero di dischi.
Spazio libero/occupato
Per sapere quant'è lo spazio libero e/o occupato si consiglia l'uso di
btrfs filesystem usage -T /punto/di/mount/desiderato/
invece del solito df
poiché querst'ultimo quando utilizzato su volumi btrfs potrebbe potenzialmente restituire valori significativamente diversi dal vero.
Altri comandi utili in tal senso sono btrfs filesystem show
e btrfs device usage
.
Manutenzione volumi
Suggerimento Leggere attentamente sia il manuale di btrfsmaintenance che il documento /usr/share/doc/btrfsmaintenance/README.Debian .
|
Al momento l'unico script raccomandato è quello per l'esecuzione delle operazioni di scrub, lasciare quindi disattivati gli altri.
La configurazione base di questo strumento considera come volume predefinito da controllare la radice, cioè /
, se però questo non è il vostro caso allora è necessario
- editare il file
/etc/default/btrfsmaintenance
- cercare la riga contenente il parametro
BTRFS_SCRUB_MOUNTPOINTS
e modificare il valore predefinito col punto di mount del proprio volume (è possibile specificare più percorsi separandoli con il carattere:
).
Fatto ciò è necessario aggiungere a CRON gli script relativi alle operazioni che sono state attivate, quindi digitare
# /usr/share/btrfsmaintenance/btrfsmaintenance-refresh-cron.sh
ATTENZIONE Questo script deve essere eseguito ogni volta che si apportano modifiche a /etc/default/btrfsmaintenance .
|
Se per esempio si è attivato come consigliato il solo script di scrub e non si è cambiata la frequenza allora digitando
ls -hl /etc/cron*
lo script dovrebbe comparire in /etc/cron.monthly
, ovvero tra le varie informazioni stampate a video si dovrebbe vedere qualcosa di simile a
/etc/cron.monthly: totale 4,0K -rwxr-xr-x 1 root root 313 10 gen 2023 0anacron lrwxrwxrwx 1 root root 42 29 dic 19.04 btrfs-scrub -> /usr/share/btrfsmaintenance/btrfs-scrub.sh
Systemd Stando a quanto scritto in /usr/share/doc/btrfsmaintenance/README.Debian dovrebbe essere possibile attivare gli script anche in systemd , ma al momento chi scrive non ci è riuscito.
|
Esempi
Disco/partizione singoli
single+dup
Si noti che questa configurazione NON OFFRE:
- la possibilità di correggere eventuali errori nei dati, ma solo la possibilità di verificare se gli stessi sono integri o meno;
- ridondanza hardware;
Posto quindi che la partizione da usare per il volume btrfs esista già e sia identificata da /dev/sdX1
il comando da digitare per creare il volume è:
ATTENZIONE Quest'operazione implica la cancellazione permanente di tutti i dati sulla partizione. |
# mkfs.btrfs -f -L nome_etichetta -d single -m dup /dev/sdX1
dove le opzioni -d
e -m
avrebbero potuto essere omesse poiché i valori specificati coincidono con quelli predefiniti.
dup+dup
Questa casistica è simile al raid1, infatti rispetto al caso precedente anche i dati vengono duplicati, ma sullo stesso disco.
Avvertimento Con questa configurazione lo spazio totale realmente disponibile sarà la metà di quello teorico e NON viene fornita ridondanza hardware. |
In sintesi rispetto al caso precedente questa configurazione permette anche la possibilità di correggere eventuali errori nei dati, non solo di verificarne l'integrità.
Posto quindi che la partizione da usare per il volume btrfs esista già e sia identificata da /dev/sdX1
il comando da digitare per creare il volume è:
ATTENZIONE Quest'operazione implica la cancellazione permanente di tutti i dati sulla partizione. |
# mkfs.btrfs -f -L nome_etichetta -d dup -m dup /dev/sdX1
dove l'opzione -m
avrebbe potuto essere omessa poiché il valore specificato coincide con quello predefinito.
Raid1 dati e metadati, sei dischi
Ipotesi
- si hanno a disposizione sei dischi a due a due di identiche dimensioni e precisamente pari rispettivamente a 3TB, 2TB ed 1,5TB;
- i dischi siano identificati come
/dev/sdU
(3TB),/dev/sdV
(2TB),/dev/sdW
(1,5TB),/dev/sdX
(3TB),/dev/sdY
(2TB),/dev/sdZ
(1,5TB); - i dischi non sono nuovi e contengono dati;
- ciascun disco contiene gli stessi dati dell'altro avente pari dimensioni, ad es. il i due dischi da 3TB contengono ciascuno una copia degli stessi dati;
Obiettivo
Creare un volume btrfs raid1 da 6,5TB di spazio totale composto da tutti e sei i dischi, ma senza dover necessariamente copiare prima i dati già presenti altrove.
Avvertimento Si consiglia caldamente di fare una copia di backup dei dati presenti sui dischi che andranno a comporre il volume btrfs prima di iniziare le operazioni. |
Passo 1
Selezionare tre dischi tutti di differente capacità e pulirli
ATTENZIONE Quest'operazione implica la cancellazione permanente di tutti i dati dai dischi puliti. |
# wipefs -a /dev/sdU /dev/sdV /dev/sdW
Passo 2
Ripartizionare i tre dischi
# parted /dev/sdU mklabel gpt mkpart nome_desiderato1 btrfs 0% 100% # parted /dev/sdV mklabel gpt mkpart nome_desiderato2 btrfs 0% 100% # parted /dev/sdW mklabel gpt mkpart nome_desiderato3 btrfs 0% 100%
Passo 3
Formattare i 3 dischi e contestualmente creare il volume btrfs
# mkfs.btrfs -f -L nome_etichetta -d single -m raid1 /dev/sdU1 /dev/sdV1 /dev/sdW1
A questo punto digitando il comando # lsblk -f
si vedrà che l'UUID di tutte e tre le partizioni è il medesimo.
Passo 4
Montare il volume btrfs appena creato o specificando il primo disco dei tre o l'UUID (visibile tramite lsblk -f
per esempio) del volume btrfs:
# mount /dev/sdU1 /punto/di/mount/desiderato/
Passo 5
Copiare tutti i dati dai dischi /dev/sdX /dev/sdY /dev/sdZ
sul nuovo volume btrfs.
Avvertimento Se i dati da copiare sono molti, ad esempio qualche TB, l'operazione potrebbe richiedere anche uno o più giorni. |
Passo 6
Pulire anche i tre dischi rimanenti.
ATTENZIONE Quest'operazione implica la cancellazione permanente di tutti i dati dai dischi puliti. |
# wipefs -a /dev/sdX /dev/sdY /dev/sdZ
Passo 7
Ripartizionare anche i tre dischi rimanenti
# parted /dev/sdX mklabel gpt mkpart nome_desiderato4 btrfs 0% 100% # parted /dev/sdY mklabel gpt mkpart nome_desiderato5 btrfs 0% 100% # parted /dev/sdZ mklabel gpt mkpart nome_desiderato6 btrfs 0% 100%
Passo 8
Aggiungere i tre dischi appena puliti al nostro volume btfrs (che DEVE essere montato)
# btrfs device add -f /dev/sdX1 /dev/sdY1 /dev/sdZ1 /punto/di/mount/desiderato/
Passo 9
Convertire i dati del volume btrfs da single
a raid1
.
Avvertimento Se i dati da copiare sono molti, ad esempio qualche TB, l'operazione potrebbe richiedere anche uno o più giorni. |
# btrfs balance start -v -dconvert=raid1 /punto/di/mount/desiderato/
Qualora inizialmente non si fosse scelto il profilo raid1
per i metadati sarebbe possibile convertire al volo anche gli stessi semplicemente aggiungendo l'opzione -mconvert=raid1
al precedente comando.
Passo 10
Al termine dell'operazione di bilanciamento verrà stampato a video
Done, had to relocate ABC out of DEF chunks
e il prompt del terminale sarà di nuovo usabile.
Il volume è ora pronto e il suo stato può essere indagato con tre comandi di cui il primo è:
# btrfs filesystem show /punto/di/mount/desiderato/
che restituirà una sintesi simile a
Label: 'nome_etichetta' uuid: ABCDEFGH-... Total devices 6 FS bytes used 4.05TiB devid 1 size 1.82TiB used 1.23TiB path /dev/sdV1 devid 2 size 2.73TiB used 1.96TiB path /dev/sdU1 devid 3 size 1.36TiB used 793.01GiB path /dev/sdW1 devid 4 size 1.82TiB used 1.23TiB path /dev/sdY1 devid 5 size 2.73TiB used 2.14TiB path /dev/sdX1 devid 6 size 1.36TiB used 793.00GiB path /dev/sdZ1
Il secondo comando è invece
# btrfs filesystem usage -T /punto/di/mount/desiderato/
e stamperà a video qualcosa di simile a:
Overall: Device size: 11.83TiB Device allocated: 8.10TiB Device unallocated: 3.72TiB Device missing: 0.00B Device slack: 0.00B Used: 8.09TiB Free (estimated): 1.87TiB (min: 1.87TiB) Free (statfs, df): 1.77TiB Data ratio: 2.00 Metadata ratio: 2.00 Global reserve: 512.00MiB (used: 0.00B) Multiple profiles: no Data Metadata System Id Path RAID1 RAID1 RAID1 Unallocated Total Slack -- --------- --------- -------- --------- ----------- -------- ----- 1 /dev/sdV1 1.22TiB 5.00GiB - 605.02GiB 1.82TiB - 2 /dev/sdU1 1.95TiB 6.00GiB 8.00MiB 790.51GiB 2.73TiB - 3 /dev/sdW1 792.00GiB 1.00GiB 8.00MiB 604.26GiB 1.36TiB - 4 /dev/sdY1 1.23TiB - - 605.02GiB 1.82TiB - 5 /dev/sdX1 2.14TiB - - 604.52GiB 2.73TiB - 6 /dev/sdZ1 793.00GiB - - 604.26GiB 1.36TiB - -- --------- --------- -------- --------- ----------- -------- ----- Total 4.04TiB 6.00GiB 8.00MiB 3.72TiB 11.83TiB 0.00B Used 4.04TiB 4.36GiB 608.00KiB
Infine il terzo è
# btrfs device usage /punto/di/mount/desiderato/
che resituirà qualcosa di simile a:
/dev/sdV1, ID: 1 Device size: 1.82TiB Device slack: 0.00B Data,RAID1: 1.22TiB Metadata,RAID1: 5.00GiB Unallocated: 605.02GiB /dev/sdU1, ID: 2 Device size: 2.73TiB Device slack: 0.00B Data,RAID1: 1.95TiB Metadata,RAID1: 6.00GiB System,RAID1: 8.00MiB Unallocated: 790.51GiB /dev/sdW1, ID: 3 Device size: 1.36TiB Device slack: 0.00B Data,RAID1: 792.00GiB Metadata,RAID1: 1.00GiB System,RAID1: 8.00MiB Unallocated: 604.26GiB /dev/sdY1, ID: 4 Device size: 1.82TiB Device slack: 0.00B Data,RAID1: 1.23TiB Unallocated: 605.02GiB /dev/sdX1, ID: 5 Device size: 2.73TiB Device slack: 0.00B Data,RAID1: 2.14TiB Unallocated: 604.52GiB /dev/sdZ1, ID: 6 Device size: 1.36TiB Device slack: 0.00B Data,RAID1: 793.00GiB Unallocated: 604.26GiB
Passo 11
Editare il file /etc/default/btrfsmaintenance
sostituendo al valore predefinito di BTRFS_SCRUB_MOUNTPOINTS
quello scelto (/punto/di/mount/desiderato/
in questo esempio) e infine attivare i servizi btrfsmaintenance-refresh.service
e btrfs-scrub.timer
come descritto nell'apposita sezione di questa guida.
Approfondimenti
Manpages
Sitografia
- Documentazione ufficiale
- Pagina wiki Debian
- Forza's ramblings btrfs wiki
- Btrfs, pagina inglese di wikipedia
- Articolo introduttivo
Guida scritta da: Wtf (discussioni) 17:58, 25 dic 2024 (UTC) | Debianized 20% |
Estesa da: | |
Verificata da: | |
Verificare ed estendere la guida | Cos'è una guida Debianized |