Btrfs: differenze tra le versioni

Da Guide@Debianizzati.Org.
Vai alla navigazione Vai alla ricerca
 
(56 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 wikipedia:
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à).}}
Riga 26: 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 34: 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 deu o più.
* <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 la metà della somma dei dischi/partizioni che compongono il volume, e non 1/N (con N = n. totale dischi/partizioni);
:* 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. È comunque consigliato avere dischi/partizioni di pari dimensioni.
:* 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 con sei dischi ===
=== 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> (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 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);
Riga 57: Riga 106:
* 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 ====
'''Obiettivo'''<br/>
Creare un volume ''btrfs raid1'' da 6,5TB di spazio totale composto da tutti e sei i dischi, ma senza dover copiare prima i dati già presenti altrove.
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 ====
'''Passo 1'''<br/>
Selezionare tre dischi tutti di differente capacità e pulirli
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 ====
'''Passo 2'''<br/>
Ripartizionare i tre dischi
Ripartizionare i tre dischi
<pre>
<pre>
Riga 72: Riga 123:
</pre>
</pre>


==== Passo 3 ====
'''Passo 3'''<br/>
Formattare i 3 dischi e contestualmente creare il volume ''btrfs''
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>
<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</code> si vedrà che l'UUID di tutte e tre le partizioni è il medesimo.
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 ====
'''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'':
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 ====
'''Passo 5'''<br/>
Copiare tutti i dati dai dischi <code>/dev/sdX /dev/sdY /dev/sdZ</code> sul nuovo volume ''btrfs''.
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 88: 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://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://wiki.tnonline.net/w/Category:Btrfs Forza's ramblings btrfs wiki]
* [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

File System e dispositivi fisici
Arrow left.png

Generalità

Locali

Remoti

Strumenti

Arrow right.png


Debian-swirl.png 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.

Warning.png 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.


Info.png 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à).
Bulb.png 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

Warning.png 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 oppure raid1 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.

Bulb.png 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.
Attention.png Avvertimento
Nel caso di disco singolo se si sceglie profilo single per i dati e dup 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 dup sia per i dati che metadati.
  • 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.
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.
Bulb.png 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 di raid1, 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

Bulb.png 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
Warning.png 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
Info.png 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:

  1. la possibilità di correggere eventuali errori nei dati, ma solo la possibilità di verificare se gli stessi sono integri o meno;
  2. 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 è:

Warning.png 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.

Attention.png 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 è:

Warning.png 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.

Attention.png 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

Warning.png 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.

Attention.png 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.

Warning.png 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.

Attention.png 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

  • man btrfs, HTML
  • man mkfs.btrfs, HTML
  • man btrfsmaintenance, HTML

Sitografia




Guida scritta da: Wtf (discussioni) 17:58, 25 dic 2024 (UTC) Swirl-auth20.png Debianized 20%
Estesa da:
Verificata da:

Verificare ed estendere la guida | Cos'è una guida Debianized