Attenzione! Questa è una Pagina di prova. Le informazioni riportate potrebbero essere incomplete, errate e potenzialmente pericolose. Per contribuire alla realizzazione di questa pagina consultare la discussione di riferimento.

Guida verificata con Ubuntu: 20.04

Introduzione

Per Linux Software RAID si intende una particolare tipologia di RAID il cui funzionamento dipende da un driver software e non richiede hardware dedicato. Per contro, i sistemi fake RAID possono essere realizzati solo in presenza di una scheda madre compatibile, e gli hardware RAID richiedono specifici controller dedicati.

Il tool software che consente la creazione e la gestione degli array Linux Software RAID è mdadm, la cui installazione comprende il driver md. Questo pacchetto non è preinstallato in Ubuntu desktop ma è presente nei repository ufficiali.

Gli elementi che compongono un array possono essere interi dischi, ad esempio sda ed sdb, oppure singole partizioni, ad esempio sda1 ed sdb1. Ciò significa che sugli stessi dischi possono coesistere diversi array con diversi livelli RAID. Ad esempio utilizzando i dischi sda ed sdb è possibile creare un RAID 1 con le partizioni sda1 ed sdb1 e un RAID 0 con le partizioni sda2 ed sdb2.

I dischi coinvolti in un array dovrebbero avere le medesime caratteristiche hardware. L'ideale è che siano della stessa marca e modello. Inoltre tutti gli elementi dell'array, anche se si tratta di partizioni, devono avere la medesima dimensione. Fanno eccezione gli array di livello Linear (o JBOD) che possono includere elementi con caratteristiche differenti.

Nomenclatura degli array

Gli array software vengono visti dal sistema come dispositivi virtuali detti multi-disk (md) e assumono una nomenclatura del tipo mdN, dove N è un numero maggiore o uguale zero, ad esempio md0, md1, ecc...
Le partizioni all'interno di un array vengono indicate come pN, dove N è un numero maggiore o uguale a 1, ad esempio md0p1, md0p2, ecc... Tuttavia, in casi particolari, l'array può essere privo di tabella delle partizioni, pertanto il solo nome dell'array (mdN senza pN) sì riferirsi all'unica partizione presente nell'array. Per maggiori dettagli consultare il paragrafo Metadati.

Livelli RAID supportati

Oltre a quasti livelli RAID sono supportate ulteriori modalità, come Container, Faulty e Multipath. Per maggiori informazioni consultare il manuale di md.

Metadati

I metadati sono una piccola quantità di dati memorizzata nel superblocco. Il loro scopo è conservare informazioni sulla struttura e sullo stato dell'array. Le versioni di metadati supportate sono le seguenti:

Per impostazione predefinita vengono usati i metadati versione 1.2. Per specificare una versione diversa utilizzare il parametro --metadata= (oppure -e) al momento della creazione . Per utilizzare la versione 1.0 specificare 1.0 e non 1.

Peculiarità dei metadati versione 0.90 e 1.0

I metadati versione 0.90 e 1.0 sono accomunati dal fatto che il superblocco si trova alla fine del disco. Da questa caratteristica derivano alcune peculiarità.

Se il primo elemento dell'array è una partizione, l'array sarà esso stesso una partizione, senza una tabella delle partizioni. In questo caso il nome dell'array (ad esempio md0) si riferisce a quell'unica partizione. Per tutti i livelli RAID eccetto il livello 1 è necessario formattare l'array con un file system oppure assegnargli una tabella e suddividerlo in partizioni. Gli array di livello 1 invece mantengono inalterato il file system e tutti i dati della prima partizione che li costituisce.
Ad esempio, se sda1 ed sdb1 sono il primo e secondo elemento di un array di livello 1, questo sarà privo di tabella delle partizioni e avrà lo stesso file system e i dati di sda1. Trattandosi di un array di livello 1, file system e dati verranno replicati perfettamente su sdb1. Di conseguenza l'eventuale file system e i dati di sdb1 verranno distrutti.

Sempre in riferimento agli array di livello 1, quando l'array non è attivo le partizioni che lo compongono sono accessibili in lettura e scrittura singolarmente, in modo indipendente. Se viene modificato il contenuto della partizione che funge da primo elemento, quando l'array viene riassemblato queste modifiche vengono replicate sugli altri elementi dell'array. Al contrario se viene modificato il contenuto di un altro elemento, quando l'array viene riassemblato queste modifiche non vengono mantenute e viene ripristinata una perfetta replica del primo elemento dell'array.
Ad esempio, se sda1 ed sdb1 sono il primo e secondo elemento di un array di livello 1, quando l'array non è attivo è possibile accedere in lettura e scrittura alle due partizioni in modo indipendente. Essendo sda1 il primo elemento dell'array, qualsiasi modifica apportata al suo contenuto verrà poi replicata su sdb1 quando l'array verrà riassemblato. Al contrario le modifiche apportate a sdb1 andranno perse, rimpiazzate da una perfetta replica di sda1.

Prendendo in considerazione una situazione reale, in un sistema UEFI il firmware della scheda madre all'avvio deve poter accedere alla partizione EFI. Pertanto un'eventuale array EFI dovrà essere necessariamente di livello 1 e utilizzare i metadati versione 0.90 o 1.0. Inoltre se nel sistema è già presente una partizione EFI e questa contiene i file di avvio di altri sistemi operativi (multiboot), questa partizione dovrà essere indicata come primo elemento dell'array. In caso contrario i file di avvio degli altri sistemi andrebbero distrutti.

Creare un array

Il comando per creare un array è il seguente:

sudo mdadm --create /dev/<nome array> --level=<livello raid> --raid-devices=<numero elementi> /dev/<primo elemento> /dev/<ennesimo elemento>

Seguono alcuni esempi pratici:

Eliminare un array

Nei passaggi seguenti sostituire /dev/mdN con l'array da eliminare, ad esempio /dev/md0, e /dev/sdX con i dispositivi o le partizioni che lo compongono, ad esempio /dev/sda o /dev/sda1.

  1. Se montato, smontare l'array digitando il seguente comando nel terminale:

    sudo umount /dev/mdN
  2. Disattivare l'array digitando il seguente comando nel terminale:

    sudo mdadm --stop /dev/mdN
  3. Rimuovere i metadati presenti sui dispositivi o partizioni che compongono l'array digitando per ciascuno di essi il seguente comando nel terminale:

    sudo mdadm --zero-superblock /dev/sdX
  4. Aprire con un editor di testo e con i privilegi di amministrazione il file /etc/mdadm/mdadm.conf.

  5. Se presente, rimuovere o commentare la riga che fa riferimento all'array che si intende eliminare. La riga avrà un formato di questo tipo:

    ARRAY /dev/mdN metadata=N.N name=mdadmwrite:N UUID=XXXXXXXX:XXXXXXXX:XXXXXXXX:XXXXXXXX
  6. Salvare il file e chiudere l'editor di testo.
  7. Aggiornare initramfs digitando il seguente comando nel terminale:

    sudo update-initramfs -u
  8. Se in fstab sono presenti riferimenti all'array o a sue partizioni, rimuoverli.

Accedere ad un array da una sessione live

  1. Installare il pacchetto mdadm.

  2. Assemblare l'array digitando uno dei seguenti comandi nel terminale:

    • Per assemblare tutti gli array presenti nel sistema:

      sudo mdadm --assemble --scan
    • Per assemblare un singolo array:

      sudo mdadm --assemble /dev/<nome array>

      Sostituire <nome array> con il nome dell'array da assemblare, ad esempio md0.

Ottenere informazioni su un array

Montare un elemento di un array in modo indipendente dall'array

Questa operazione è possibile solo per gli array di livello 1 con metadati versione 0.90 o 1.0.

Nei passaggi seguenti sostituire /dev/mdN con il nome dell'array, ad esempio /dev/md0, e /dev/sdX con la partizione che si desidera montare in modo indipendente, ad esempio /dev/sda1.

Le modifiche apportate alla partizione che funge da primo elemento dell'array vengono automaticamente replicate sugli altri elementi quando l'array viene riassemblato. Di conseguenza le modifiche apportate ad altri elementi dell'array non vengono mantenute.

  1. Se montato, smontare l'array digitando il seguente comando nel terminale:

    sudo umount /dev/mdN
  2. Disattivare l'array digitando il seguente comando nel terminale:

    sudo mdadm --stop /dev/mdN
  3. Montare la partizione digitando il seguente comando nel terminale:

    sudo mount -t <file system> /dev/mdN <punto di montaggio>

    Sostituire <file system> con il file system in cui è formattata la partizione, ad esempio ext4, e <punto di montaggio> con il percorso in cui montare la partizione, ad esempio /mnt.

Risoluzione dei problemi

Gli array non sono visibili da altri altri sistemi operativi

Perché un sistema operativo possa gestire gli array Linux software RAID è necessario che sia installato il tool mdadm e il driver md. Per Ubuntu e derivate valgono le istruzioni esposte nel paragrafo Accedere ad un array da una sessione live. Sistemi operativi non Linux potrebbero non essere compatibili, se non mediante software di recupero dati o altri tool di terze parti.

== Nel menù di avvio di Grub non compare Windows (UEFI)==

Per rilevare altri sistemi operativi il comando update-grub si serve di os-prober, il quale fa una ricerca nelle altre partizioni del sistema.

Il boot loader di Windows risiede nella partizione EFI, ma se questa fa parte di un array Linux software RAID (come spiegato in questa guida) non è possibile accedervi mentre l'array è attivo. Inoltre os-prober non cerca il boot loader di Windows all'interno di array Linux software RAID ma solo in partizioni EFI standard.

Per risolvere questo problema è quindi necessario smontare e disattivare l'array EFI prima che update-grub invochi os-prober. In seguito è necessario riattivare l'array EFI e rimontarlo.

L'operazione può essere automatizzata apportando una modifica al file /etc/grub.d/30_os-prober, come spiegato di seguito:

  1. Creare una copia di backup del file /etc/grub.d/30_os-prober digitando il seguente comando nel terminale:

    sudo cp /etc/grub.d/30_os-prober /etc/grub.d/.30_os-prober.bak

    In caso di problemi sarà possibile ripristinare la copia di backup digitando il comando sudo mv /etc/grub.d/.30_os-prober.bak /etc/grub.d/30_os-prober

  2. Aprire con un editor di testo e con i privilegi di amministrazione il file /etc/grub.d/30_os-prober.

  3. Sostituire la seguente riga:

    OSPROBED="`os-prober | tr ' ' '^' | paste -s -d ' '`"

    con

    md=false
    esp="$(findmnt -nosource /boot/efi)"
    if [[ "$esp" == '/dev/md'* ]]; then
      md=true
      umount '/boot/efi'
      mdadm -S $esp
    fi
    
    OSPROBED="`os-prober | tr ' ' '^' | paste -s -d ' '`"
    
    if $md; then
      mdadm -A $esp
      sleep 1
      mount '/boot/efi'
    fi
  4. Salvare il file e chiudere l'editor.
  5. Aggiornare la configurazione di Grub digitando il seguente comando nel terminale:

    sudo update-grub

    Verrà rilevata una voce Windows Boot Manager per ciascuna partizione facente parte dell'array EFI.

Uno o più dischi hanno smesso di funzionare

La tolleranza ai guasti degli array RAID varia in base al livello. La tabella seguente illustra i casi in cui l'array è completamente ripristinabile, parzialmente ripristinabile o non ripristinabile:

Livello RAID

1 disco guasto

2 dischi guasti

Tutti guasti eccetto 1

Linear

Parziale

Parziale

Parziale

0

No

No

No

1

Completo

Completo

Completo

4

Completo

No

No

5

Completo

No

No

6

Completo

Completo

No

Nei casi in cui è possibile un ripristino completo, l'array continua a funzionare nonostante il guasto e tutti i dati sono integri ed accessibili. Una volta sostituiti i dischi guasti e, se opportuno, create le partizioni necessarie, sarà possibile aggiungere i nuovi elementi all'array, in modo da ripristinarne le struttura, la ridondanza e le prestazioni.

Per gli array di livello Linear è possibile un ripristino parziale, nel senso che vengono compromessi solo i dati presenti nei dischi danneggiati. Inoltre la dimensione dell'array si riduce alla somma degli elementi funzionanti restanti. Una volta sostituiti i dischi guasti e, se opportuno, create le partizioni necessarie, sarà possibile aggiungere i nuovi elementi all'array, in modo da ripristinarne le dimensioni originali.

Nei casi in cui il ripristino non è possibile, l'array smette di funzionare e tutti i dati sono compromessi. Una volta sostituiti i dischi guasti e, se opportuno, create le partizioni necessarie, sarà possibile ricreare l'array da zero.

Se i dischi non funzionanti sono ancora visibili dal sistema, è possibile tentare di recuperarne il contenuto. Per maggiori informazioni consultare la guida dedicata

iononsbalgiomai/SoftwareRaid (l'ultima modifica è del 13/11/2021 23.18.36, fatta da iononsbalgiomai)