LVM/it

LVM (Logical Volume Manager) consente agli amministratori di creare meta dispositivi che forniscono un livello di astrazione tra un file system e la memoria fisica che viene utilizzata al di sotto. I meta dispositivi (su cui sono posti i file systems) sono "volumi logici", che utilizzano memoria dai lotti di memoria chiamati "volume groups". Un "volume groups" (gruppo di volumi) viene fornito con uno o più "physical volumes" (volumi fisici), che sono i veri dispositivi su cui sono memorizzati i dati.

I volumi fisici possono essere partizioni, interi hard disk SATA raggruppati come JBOD (Just a Bunch Of Disks), sistemi RAID, iSCSI, Fibre Channel, eSATA ecc...

Installazione
LVM è gestita da entrambi, drivers kernel-level e applicazioni su spazio utente (user-space), per gestire la configurazione di LVM.

Kernel
Attivare le seguenti opzioni del kernel:

Emerge
Dopo aver ricontrollato le opzioni USE, chiedere a Portage di installare il pacchetto :

Configurazione
La configurazione di LVM è eseguita su più livelli:
 * 1) Gestione di LV, PV e VG attraverso le utilità di gestione;
 * 2) Messa a punto del sottosistema LVM attraverso il file di configurazione;
 * 3) La gestione dei servizi a livello di distribuzione;
 * 4) Configurazione tramite una ram iniziale del file system (initramfs).

La gestione dei volumi logici e fisici nonché i gruppi di volumi viene gestita tramite il capitolo Utilizzo.

File di configurazione di LVM
LVM ha un vasto file di configurazione in. La maggior parte degli utenti non avranno bisogno di modificare le impostazioni in questo file per iniziare ad utilizzare LVM.

Gestione del servizio
Gentoo fornisce il servizio di LVM per rilevare e attivare i gruppi di volumi e i volumi logici automaticamente.

Il servizio può essere gestito attraverso il sistema di init.

openrc
Per avviare LVM manualmente:

Per avviare LVM in fase di avvio:

systemd
Per avviare LVM manualmente:

Per avviare LVM in fase di avvio:

Utilizzare LVM in un initramfs
La maggior parte dei bootloader non può essere avviata direttamente da LVM - né GRUB legacy né LILO possono farlo. Grub 2 PUO' avviare da un volume logico LVM lineare, volume logico con mirroring e forse alcuni tipi di volumi logici RAID. Attualmente nessun bootloader supporta volumi logici sottili.

Per questa ragione è raccomandabile utilizzare una partizione di avvio non-LVM e montare la root LVM da initramfs. Tale initramfs può essere generato automaticamente tramite genkernel, e dracut:


 * può avviare da tutti i tipi tranne dai volumi sottili (in quanto non costruisce la copia del pacchetto binario dall'host di compilazione) e forse anche RAID10 (il supporto RAID10 richiede LVM2 2.02.98, ma genkernel 2.02.89, tuttavia, se i binari statici sono disponibili, può copiare quelli);
 * può avviare da tutti i tipi di volumi, ma ha bisogno di un nuovo pacchetto o i binari sottili risultanti saranno rotti (See );
 * dovrebbe avviare tutti i tipi, ma include solo il supporto sottile initramfs se l'host viene eseguito su una root sottile.

Genkernel/Genkernel-next
Emergere o il pacchetto o ilpacchetto. La USE flag statica può anche essere abilitata per il pacchetto così che genkernel utilizzerà il sistema binario (altrimenti compilerà la propria copia privata). Il seguente esempio compilerà solo un initramfs (non un interno kernel) e abiliterà il supporto per LVM.

La pagina di manuale di genkernel delinea le altre opzioni a seconda delle esigenze del sistema.

L'initrd richiederà i parametri per stabilire come avviare LVM, ed essi sono forniti allo stesso modo di altri parametri del kernel. Per esempio:

Dracut
Il pacchetto è stato importato dal progetto Red Hat e offre uno strumento simile per generare un initramfs. Dal momento che è attualmente in ~arch per essere testato, gli utenti dovranno accept it (mediante ) per emergerlo. Prima di fare ciò, la variabile  dovrebbe essere aggiunta sul file. Altri moduli possono essere desiderati, fare riferimento al Dracut. In generale, il seguente comando genererà un predefinito initramfs funzionale.

L'initrd richiederà parametri per stabilire come avviare LVM, e questi sono in dotazione come gli altri parametri del kernel. Per esempio:

Per una lista globale delle opzioni di LVM all'interno di vedere la sezione nel Manuale di Dracut.

Utilizzo
LVM organizza la memoria in tre diversi livelli come segue:
 * dichi fissi, partizioni, sistemi RAID o altri mezzi di memorizzazione vengono inizializzati come Volumi Fisici (PVs)
 * Volumi fisici (PV) sono raggruppati in Gruppi di Volumi (VG)
 * Volumi logici (LV) sono gestiti in Gruppi di Volumi (VG)

PV (Volume Fisico)
I Volumi Fisici sono gli attuali hardware o sistemi di memoria di LVM.

Partizionamento
Il tipo di partizione per "LVM" è "8e" (LVM Linux).

Ad esempio, per impostare il tipo tramite per una partizione su :

In, creare partizioni utilizzando il tasto e variare il tipo di partizione con il tasto  a "8e".

Creare PV
I volumi fisici possono essere creati/inizializzati con il comando.

Ad esempio, il seguente comando crea un volume fisico nella prima partizione primaria di e :

Lista PV
Con il comando, si può avere una panoramica di tutti i volumi fisici attivi sul sistema.

Se devono essere visualizzati più volumi fisici, può rilevare i volumi fisici inattivi, quindi attivarli.

Rimuovere PV
LVM distribuisce automaticamente i dati su tutti i volumi fisici disponibili (a meno che non impostato diversamente), ma in un approccio lineare. Se un richiesto volume logico (all'interno di un gruppo di volumi) è più piccolo rispetto alla quantità di spazio libero di un solo volume fisico, tutto lo spazio per il volume logico viene rivendicato su quel (singolo) volume fisico in modo contiguo. Questo viene fatto per motivi di prestazioni.

Se un volume fisico deve essere rimosso da un gruppo di volumi, i dati devono prima essere rimossi dal volume fisico. Con il comando  tutti i dati su un volume fisico vengono spostati su un altro volume fisico all'interno dello stesso gruppo di volumi.

Tale operazione può richiedere tempo a seconda della quantità di dati che devono essere spostati. Una volta terminata, non ci dovrebbero essere dati rimasti sul dispositivo. Verificare con pvdisplay che il volume fisico non è più utilizzato da nessun volume logico.

Il prossimo passo è rimuovere il volume fisico dal gruppo di volumi utilizzando, dopodichè il dispositivo può essere "deselezionato" come volume fisico utilizzando pvremove:

VG (Gruppo di Volumi)
Un gruppo di volumi (VG) raggruppa un numero di volumi fisici e si presenta come nel file system del dispositivo. Il nome di un gruppo di volumi è scelto dall'amministratore.

Creare VG
Il seguente comando crea un gruppo di volumi chiamato "vg0" con due volumi fisici assegnati: e.

Elenco VG
Per elencare tutti i gruppi di volumi attivi, utilizzare il comando :

Se i gruppi di volume sono mancanti, utilizzare il comando per localizzarli:

Estendere VG
I gruppi di volume raggruppano i volumi fisici, permettendo agli amministratori di utilizzare un pool di risorse di memoria da destinare ai file systems. Quando un gruppo di volumi non ha sufficienti risorse di memoria, è necessario estendere il gruppo di volumi con volumi fisici aggiuntivi.

Il seguente esempio amplia il gruppo di volumi "vg0" di un volume fisico su :

Si ricorda che il volume fisico deve prima essere inizializzato come tale!

Ridurre VG
Se i volumi fisici devono essere rimossi dal gruppo di volumi, tutti i dati ancora in uso nel volume fisico devono essere spostati ad altri volumi fisici nel gruppo di volumi. Come visto prima, questo viene gestito tramite il comando, dopodichè il volume fisico può essere rimosso dal gruppo di volumi utilizzando vgreduce:

Rimuovere VG
Se un gruppo di volumi non è più necessario (o, in altre parole, il lotto di memoria che rappresenta non viene più utilizzato e i volumi fisici in esso contenuti necessitano di essere liberati per altri scopi), tale gruppo di volumi può essere rimosso con vgremove. Questo funziona solo se nessun volume logico è definito per il gruppo di volumi, e tutti, tranne un volume fisico, sono già stati rimossi dal lotto di memoria.

LV (Volume Logico)
I volumi logici sono i dispositivi meta finali che sono messi a disposizione dal sistema di solito per crearci sopra i file system. Essi vengono creati e gestiti in gruppi di volumi e si presentano come. Come per i gruppi di volumi, il nome usato per un volume logico è deciso dall'amministratore.

Creare LV
Per creare un volume logico si utilizza il comando. I parametri per il comando sono la dimensione richiesta per il volume logico (che non può essere più grande della quantità di spazio libero nel gruppo di volumi), il gruppo di volumi da cui lo spazio è rivendicato ed il nome del volume logico da creare.

Nell'esempio seguente, un volume logico di nome "lvol1" è stato creato dal gruppo di volumi chiamato "vg0" e con una dimensione di 150 MB:

È possibile utilizzare per usare tutto lo spazio libero all'interno del gruppo di volumi. Ciò viene fatto con l'opzione  la quale seleziona la quantità di "estensioni" piuttosto che la dimensione (leggibile dall'uomo). I volumi logici sono divisi in "estensioni logiche" che sono blocchi di dati all'interno di un gruppo di volumi. Tutte le estensioni in un gruppo di volumi hanno la stessa dimensione. Con l'opzione   può essere utilizzato per allocare tutte le estensioni libere:

Dopo il FREE, può essere utilizzata la chiave VG per indicare l'intera dimensione del gruppo di volume.

Elencare LV
Per elencare tutti i volumi logici, utilizzare il comando :

Se i volumi logici non compaiono, può essere utilizzato il comando per eseguire la scansione dei volumi logici su tutti i gruppi di volumi disponibili.

Estendere LV
Quando un volume logico ha bisogno di essere esteso, si può utilizzare il comando per aumentare lo spazio allocato per il volume logico.

Per esempio, per estendere il volume logico "lvol1" a un totale di 500 MB:

È anche possibile utilizzare la dimensione da aggiungere piuttosto che la dimensione totale:

Un gruppo di volumi esteso non fornisce immediatamente la memoria addizionale agli utenti finali. Per questo, il file system in cima al gruppo di volumi deve essere incrementato in termini di dimensioni pure. Non tutti i file systems consentono il ridimensionamento, quindi, per ulteriori informazioni, controllare la documentazione per il file system in questione.

Per esempio, per ridimensionare un file system ext4 e farlo diventare con dimensione da 500 MB:

Per certi file systems, lvreseize estende il volume logico e il file system in un solo passaggio. Ad esempio, per estendere il volume logico lvol1 e ridimensionare il file system ext4:

Diminuire LV
Se un volume logico ha bisogno di essere ridotto di dimensione, per prima cosa ridurre il file system stesso. Non tutti i file system supportano la riduzione.

Per esempio, ext4 non supporta la riduzione così il file system prima deve essere smontato. E' anche raccomandato fare un controllo al file system per assicurarsi che non vi siano incongruenze:

Con la riduzione del file system, è ora possibile diminuire pure la dimensione del volume logico:

Autorizzazioni LV
LVM supporta i permessi sui volui logici.

Per esempio, un volume logico può essere impostato a "leggi solo" utilizzando il comando :

Rimontarlo è necessario in quanto la modifica non viene applicata immediatamente.

Per contrassegnare il volume logico come scrivibile di nuovo, utilizzare il permesso "rw":

Rimuovere LV
Prima di rimuovere un volume logico, assicurarsi che non sia montato:

Disattivare il volume logico in modo che nessuna ulteriore attività di scrittura possa avvenire:

Con il volume smontato e disattivato, ora può essere rimosso, liberando le estensioni ad esso attribuite per l'uso da parte di altri volumi logici nel gruppo di volumi:

Caratteristiche
LVM fornisce un bel pò di caratteristiche interessanti per gli amministratori di memoria, tra cui (ma non solo)
 * sottile approvvigionamento (memoria over-committing)
 * supporto istantaneo
 * tipi di volume con metodi di allocazione di memoria diversi

Approvvigionamento sottile
La versione più recente di LVM2 (2.02.89) supporta i volumi sottili. I volumi sottili sono per dispositivi a blocchi come sparse files sono dei file systems. Quindi, un volume logico sottile all'interno di una vasca può essere "extra-impegnato": la sua dimensione può essere maggiore della dimensione allocata - può anche essere più grande della vasca stessa. Proprio come un sparse file, le estensioni vengono allocate come il dispositivo a blocchi viene popolato. Se il file system ha "scartato" le estensioni di supporto sono liberati ancora come i files sono rimossi, riducendo l'utilizzo degli spazi della vasca.

Dentro LVM, tale vasca sottile è un tipo speciale di volume logico, che a sua volta può ospitare volumi logici.

Creazione di una vasca sottile
Ogni vasca sottile ha metadati associati ad essa, i quali vengono aggiunti alla dimensione della vasca sottile. LVM calcolerà la dimensione dei metadati in base alla dimensione della vasca sottile come il minimo di "pool_chunks * 64 bytes" o 2MiB, se superiore. L'amministratore può selezionare un formato di metadati diverso.

Per creare una vasca sottile, aggiungere le opzioni  su :

L'esempio sopra crea una vasca sottile chiamata "thin_pool" con una dimensione totale di 150 MB. Questa è la dimensione reale allocata per la vasca sottile (e quindi la quantità totale di memoria effettiva che può essere utilizzata).

Per richiedere esplicitamente una certa dimensione dei metadati, utilizzare l'opzione :

Per via che il metadata viene aggiunto alla vasca sottile, la via migliore di utilizzare tutta la dimensione disponibile in un gruppo di volumi per un volume logico, non funziona (vedere LVM bug |812726):

Si noti che la vasca sottile non ha un nodo del dispositivo associato come altri LV.

Creazione di un volume logico sottile
Un volume logico sottile è un volume logico all'interno della vasca sottile (che è essa stessa un volume logico). Come i volumi logici sottili sono scarsi, una dimensione virtuale invece di una dimensione fisica è specificata utilizzando l'opzione  :

In questo esempio, il volume logico (sottile) "lvol1" è esposto come dispositivo da 300MB di dimensione, anche se la vasca sottostante contiene solo 150MB di memoria reale allocata.

È anche possibile creare sia la vasca sottile che il volume logico all'interno della vasca sottile con un unico comando:

Elencare vasche sottili e volumi logici sottili
Le vasche sottili e i volumi logici sottili sono tipologie speciali di volumi logici, e come tali sono visualizzati tramite il comando. Il comando individuerà anche questi volumi logici.

Estendere una vasca sottile
La vasca sottile è ampliata come un volume logico non sottile utilizzando. Per esempio:

Estendere un volume logico sottile
Un volume logico sottile è ampliato regolarmente proprio come un volume logico sottile:

Notare che il comando utilizza l'opzione   (o   se si utilizzano i conteggi estesi) e non un'opzione di "dimensione virtuale" come utilizzata durante la creazione.

Ridurre una vasca sottile
Attualmente, LVM non può ridurre la dimensione della vasca sottile. Vedere il bug LVM |812731.

Ridurre un volume logico sottile
I volumi logici sottili sono ridotti regolarmente proprio come i volumi logici.

Per esempio:

Notare che il comando utilizza l'opzione   (o   se si utilizzano i conteggi estesi) e non un opzione di "dimensione virtuale" come utilizzata durante la creazione.

Rimuovere vasche sottili
Le vasche sottili non possono essere rimosse fino a che tutti i volumi logici in esse contenuti non vengono rimossi.

Quando una vasca sottile non serve più a nessun volume logico, essa può essere rimossa attraverso il comando :

LVM2 istantanee e istantanee sottili
Un'istantanea è un volume logico che agiscecome copia di un altro volume logico. Essa visualizza lo stato del volume logico originale al tempo della creazione dell'istantanea.

Creazione di un'istantanea di un volume logico
Un'istantanea di un volume logico viene creata utilizzando l'opzione  di. L'istantanea di un volume logico è sempre memoria allocata come "registro" LVM, tutte le variazioni sono fatte dal volume logico originale e questi cambiamenti vengono memorizzati nella memoria allocata per l'istantanea. LVM inizierà dal volume logico originale dopodichè controllerà tutte le variazioni registrate, "annullando" le modifiche prima di mostrare il risultato per l'utente.

L'istantanea del volume logico, d'ora in poi, "cresce" al tasso che le modifiche vengono fatte sul volume logico originale. Quando la memoria allocata per l'istantanea è utilizzata completamente, l'istantanea sarà rimossa automaticamente dal sistema.

L'esempio di sopra crea un'istantanea di volume logico chiamata "20140412_lvol1", basata sul volume logico "lvol1" nel gruppo di volume "vg0". Essa utilizza il 10% dello spazio (estensioni reali) allocato dal gruppo di volume.

Accedere ad un'istantanea di volume logico
Le istantanee dei volumi logici possono essere montate come volumi logici normali. Esse non sono nemmeno limitate a operazioni di sola lettura - è possibile modificare le istantanee e quindi utilizzarle per testare cose, tipo provare variazioni prima di effettuarle realmente su un file system di "produzione".

Finché esistono istantanee di volumi logici, il volume logico normale/originale non può essere ridotto di dimensioni e non può essere rimosso.

Istantanee sottili LVM
Per creare una istantanea sottile, il comando viene utilizzato con l'opzione. Nessuna indicazione di dimensione deve essere trasmessa:

Le istantanee sottili del volume logico hanno la stessa dimensione del loro volume logico sottile originale, ed utilizzano un'allocazione fisica di 0 proprio come tutti gli altri volumi logici.

È possibile anche ottenere istantanee di istantanee:

Le istantanee sottili hanno vari vantaggi rispetto alle istantanee regolari. Primo, le istantanee sottili sono indipendenti dal loro volume logico originale una volta create. Il volume logico originale può essere ridotto o cancellato senza influenzare l'istantanea. Secondo, l'istantanea sottile può essere efficacemente creata ricorsivamente (istantanea di un'istantanea) senza il "concatenamento" globale di regolari istantanee LVM ricorsive.

Riportare indietro allo stato di istantanea
Per riportare indietro il volume logico alla versione dell'istantanea, utilizzare il seguente comando:

Dovrebbe impiegarci una coppia di minuti, dipende dalla dimensione del volume. Prego notare che il riportare indietro si verificherà solo se il volume logico genitore sarà offline. Quindi un riavvio potrebbe essere necessario.

Riportare indietro le istantanee sottili
Per i volumi sottili, non funziona. Invece, bisogna cancellare il volume logico originale e rinominare l'istantanea:

Diversi metodi di allocazione della memoria
LVM supporta diversi metodi di allocazione di memoria:
 * Volumi lineari (che è di default);
 * Volumi mirroring (in una configurazione pressappoco attivo/standby);
 * Striping (RAID0);
 * Volumi mirroring (RAID1 - che è più una configurazione attivo/attivo);
 * Striping con parità (RAID4 e RAID5);
 * Striping con doppia parità (RAID6);
 * Striping e mirroring (RAID10).

Volumi lineari
I volumi lineari sono il tipo più comune di volumi LVM. LVM tenterà di allocare il volume logico per essere fisicamente il più contiguo possibile. Se questo è un volume fisico abbastanza grande da includere l'intero volume logico, LVM lo allocherà là, altrimenti lo frammenterà nel minor numero di pezzi possibile.

I comandi introdotti in precedenza per creare gruppi di volumi e volumi logici creano anche volumi lineari.

Visto che i volumi lineari non hanno richieste particolari, essi sono facili da manipolare e possono essere ridimensionati e riallocati a volontà. Se un volume logico è allocato attraverso multipli volumi fisici, e ogni volume fisico diventa non più disponibile, tale volume logico non può essere avviato più e sarà inutilizzabile.

Volumi Mirrored
LVM supporta i volumi "mirrored" (rispecchiati), i quali forniscono una tolleranza di errore in caso di guasto del disco. A differenza di RAID 1, non vi è alcun miglioramento delle prestazioni - tutte le letture e le scritture sono consegnate ad un solo lato del "mirror" (specchio).

Per tenere traccia dello stato del mirror, LVM richiede un "log". E' raccomandato (e spesso anche obbligatorio) posizionare questo log su un volume fisico che non contiene nessuno dei volumi logici in mirroring. Questi sono tre tipi di logs che possono essere utilizzati per i mirrors:


 * 1) Disk è il tipo di log predefinito. Tutte le variazioni fatte sono registrate su estensioni extra metadata, che vengono gestite da LVM. Se il dispositivo fallisce, le variazioni sono mantenute nel log fino a che il mirror non viene ripristinato nuovamente.
 * 2) Mirror i logs sono disk logs i quali sono loro stessi in mirroring.
 * 3) Core i logs mirror logs registra lo stato del mirror solo in memoria. LVM dovrà ricostruire il mirror ogni volta che è attivato. Questa tipologia è utile per i mirrors temporanei.

Per creare un volume logico con un singolo mirror, inserire l'opzione -m 1 (per selezionare il mirroring standard) con il codice opzionale  per selezionare un particolare tipo di log:

L'opzione "-m 1" dice a LVM di creare un (addizionale) mirror, quindi richiede 2 volumi fisici. L'opzione  è un'ottimizzazione - senza di essa LVM proverà a sincronizzare il mirror copiando i settori vuoti da un volume logico ad un altro.

È possibile creare un mirror di un volume logico esistente:

L'opzione  fa la conversione in background visto che questo può richiedere molto tempo.

Per rimuovere un mirror, impostare il numero di mirror (quello precedente) da 0:

Se parte di un mirror non è disponibile (generalmente perchè il disco contenente il volume fisico è danneggiato), il gruppo di volumi dovrà essere portato in modalità degraded:

Nella prima scrittura, LVM noterà il guasto del mirror. Il procedimento di default ("remove") è quello di ridurre automaticamente il mirror in base al numero di parti disponibili. Un mirror a 3-parti con un volume fisico mancante verrà ridotto a mirror a 2-parti; un mirror a 2-parti sarà ridotto a volume lineare regolare. Se il guasto è solo transitorio, e il volume fisico mancante ritorna dopo che LVM ha guastato il mirror, i volumi logici mirrored dovranno essere ricreati su di esso.

Per recuperare il mirror, il volume fisico guasto deve essere rimosso dal gruppo di volumi, e va aggiunto un volume fisico sostitutivo (o se il gruppo di volumi ha un volume fisico libero, il mirror può essere ricreato su questo). Ora il mirror può essere ricreato con il comando e il vecchio volume fisico può essere rimosso dal gruppo di volumi:

È possibile che LVM crei il mirror con estensioni disponibili in volumi fisici differenti se da un lato non riesce. Per realizzare questo, impostare  di "allocate" su.

Mirrors sottili
Non è ancora possibile creare una vasca sottile mirror o un volume sottile mirror. E' possibile creare una vasca sottile mirror con la creazione di un volume logico mirror normale e convertire il volume logico di una vasca sottile con il comando. 2 volumi logici sono richiesti: uno per la vasca sottile e uno per il metadata sottile; il processo di conversione li unirà in un singolo volume logico.

Striping (RAID0)
Invece di un volume lineare, dove più volumi fisici contigui vengono aggiunti, è possibile creare un volume striped o RAID 0 per migliorare le prestazioni. Questo alternerà le allocazioni di memoria attraverso i volumi fisici disponibili.

Per creare un volume striped sopra tre volumi fisici:

L'opzione  indica su quanti volumi fisici lo striping dovrebbe essere fatto.

È possibile fare il mirror di una serie di stripe. Le opzioni  e   possono essere combinate per creare un mirror striped:

Questo crea 2 serie di volumi fisici stripe e ci rispecchia 2 differenti volumi fisici, per un totale di 4 volumi fisici. Una serie di stripe esistente può essere rispecchiata con.

Una vasca sottile può essere striped come qualsiasi altro volume logico. Tutti i volumi sottili creati dalla vasca ereditano queste impostazioni - tali impostazioni non vanno specificate manualmente quando si crea un volume sottile.

Non è possibile creare lo stripe di un volume esistente, nè rimodellare gli stripes attraverso più o meno volumi fisici, nè convertire a differente volume RADI livello/lineare. Una serie di stripe possono essere rispechiati (mirrored). E' possibile estendere una serie di stripe attraverso volumi fisici addizionali, ma questi devono essere aggiunti in multipli delle serie di stripe originali (i quali efficacemente e linearmente aggiungeranno una nuova serie di stripe).

Mirroring (RAID)
A differenza di RAID0, il quale è striping, RAID1 è mirroring, ma implementato defferentemente dall'originale mirror LVM. Sotto RAID1, le letture sono distribuite su volumi fisici, migliorando le prestazioni. I guasti del mirror RAID1 non causano blocchi I/O perchè LVM non lo corrompe in scrittura.

In ogni posizione in cui il mirror LVM può essere utilizzato, un mirror RAID1 può essere usato nella stessa posizione. E' possibile che LVM crea dei mirrors RAID1 invece di mirrors regolari impostando implicitamente mirror_segtype_default di raid1 su.

Per creare un volume logico con un mirror singolo:

Notare la differenza per creare un mirror: Qui non è specificato un "mirrorlog", perchè il volume logico RAID1 non ha un mirror log esplicito - esso è integrato nel volume logico.

È possibile convertire un volume logico esistente a RAID1:

Per rimuovere un mirror RAID1, impostare il numero di mirrors a 0:

Se parte del RAID1 non è disponibile (generalmente perchè il disco contenente il volume fisico è in errore), il gruppo di volume dovrà essere portato in modalità degradata:

A differenza del mirror LVM, la scrittura non danneggia il mirroring. Se l'errore è solo transitorio, e il volume fisico mancante ritorna, LVM risincronizzerà il mirror copiando il segmento obsoleto invece che l'intero volume logico. Se l'errore è permanente, il volume fisico rovinato deve essere rimosso dal gruppo di volumi e deve essere aggiunto un volume fisico sostitutivo (o se il gruppo di volumi ha un volume fisico libero, esso può essere creato su un differente PV). Il mirror può quindi essere riparato con, e il vecchio volume fisico può essere rimosso dal gruppo di volumi:

RAID1 sottile
Non è (ancora) possibile creare una vasca sottile RAID1 o un volume sottile RAID1. E' possibile, invece, creare una vasca sottile RAID1 partendo da un volume logico mirrored che deve essere convertito in vasca sottile con il comando. Sono richiesti 2 volumi logici: uno per la vasca sottile e uno per il metadata sottile; il processo di conversione li unirà in un singolo volume logico.

Striping con parità (RAID4 e RAID5)
RAID0 non tollera errori - se qualsiasi volume fisico si guasta il volume logico diventa inutilizzabile. Aggiungendo una parity stripe al RAID0 il volume logico può ancora funzionare anche se il volume fisico è mancante. Il nuovo volume fisico può quindi essere aggiunto per ripristinare il guasto.

Stripset con parity sono disponibili in 2 versioni: RAID4 e RAID5, tutte le stripes parity sono memorizzate nello stesso volume fisico. Questo può diventare un collo di bottiglia perchè tutte le scritture interessano quel volume fisico, e peggiorano più volumi fisici che sono nell'array. Con RAID5, il parity data è distribuito in modo uniforme tra i volumi fisici in modo che nessuno di loro diventi un collo di bottiglia. Per tale ragione, RAID4 è raramente utilizzato ed è considerato obsoleto. In pratica, tutte le stripeset con parity sono RAID5.

Solo i volumi fisici di dati sono specificati con -i, e LVM ne aggiunge uno automaticamente per il parity. Così per i 3 volumi fisici RAID5, viene passato "-i 2" e non "-i 3".

Quando un volume fisico si guasta, il gruppo di volumi dovrà essere portato in modalità degradata:

Il volume, a questo punto, lavorerà normalmente, tuttavia questo degrada l'array di RAID0 fino a quando non viene aggiunto un volume fisico in sostituzione. Le prestazioni difficilmente sono influenzate quando l'array è in degrado - anche se c'è bisogno di ricalcolare i dai mancanti via parity, è richiesto semplicemente XOR per il parity block con i dati rimanenti. L'overhead è trascurabile rispetto al disco di I/O.

Per riparare RAID5:

È possibile sostituire un volume fisico che ancora sta lavorando in RAID5 così:

Le stesse restrizioni di stripeset si applicano anche a stripeset con parity: non è possibile abilitare striping con parity in un volume esistente, né rimodellare gli stripes con parity attraverso più o meno volumi fisici, né convertire in un volume di livello RAID differente. Uno stripeset con parity puè essere mirrored. E' possibile estendere uno stripeset con parity attraverso volumi fisici addizionali, ma questi devono essere aggiunti in multipli dello stripset con parity originale (che aggiungererà un nuovo stripeset con parity).

Volume logico RAID5 sottile
Non è (ancora) possibile creare vasche sottili o volumi logici stripeset con parity (RAID5). E' possibile, invece, creare una vasca sottile RAID5 creando un normale volume logico RAID5 e convertendo il volume logico in una vasca sottile con il comando. Sono richiesti 2 volumi logici: uno per la vasca sottile e uno per il metadata sottile; il processo di conversione li fonderà in un singolo volume logico.

Striping con doppia parità (RAID6)
RAID6 è simile a RAID5, tuttavia RAID6 può sopportare fino a "2" guasti del volume fisico, offrendo così maggiore tolleranza ai guasti rispetto a quella di RAID5 a scapito dei volumi fisici aggiuntivi.

Come per RADI5, l'opzione  è utilizzata per specificare il numero di volumi fisici per lo striping, escludendo i 2 volumi fisici per parity. Così, per i 5 volumi fisici RAID6 utilizzare l'opzione  e non.

Il recupero per RAID6 è lo stesso che per RAID5.

Volume logico sottile RAID6
Non è (ancora) possibile creare una vasca sottile o volumi sottili RAID6. E' possibile invece creare una vasca sottile RAID6 creando un normale volume logico RAID6 e convertendolo in vasca sottile tramite il comando. Sono richiesti 2 volumi logici: uno per la vasca sottile e uno per il metadata sottile; il processo di conversione li fonderà entrambi in un unico volume logico.

RAID10 LVM
RAID10 è una combinazione tra RAID0 e RAID1. Esso è più potente di RAID0+RAID1 come il mirroring viene fatto a livello stripe invece che a livello di volume logico, e quindi la disposizione non deve essere simmetrica. Un volume RAID10 può tollerare almeno un singolo volume fisico mancante, e forse anche più.

Entrambe le opzioni  e   vanno specificate:   indica il numero degli stripes e   il numero dei mirrors. Due stripes e 1 mirror richiedono 4 volumi fisici.

RAID10 Sottile
Non è (ancora) possibile creare una vasca sottile o volumi logici RAID10. E' invece possibile creare una vasca sottile RAID10 creando un normale volume logico RAID10 e convertendolo in vasca sottile con il comando. Sono richiesti 2 volumi logici: uno per la vasca sottile e uno per il metadata sottile; la conversione li fonderà entrambi in un singolo volume logico.

Esperimenti con LVM
È possibile fare esperimenti con LVM senza utilizzare dispositivi di memoria reali. Per realizzare questo, bisogna creare dispositivi di loopback.

Prima di tutto assicurarsi di avere il modulo loopback caricato.

Successivamente configurare LVM per non far ricercare i dispositivi a udev:

Creare alcuni files di immagine che diventeranno i dispositivi di memoria. L'esempio seguente utilizza cinque files per un totale di circa ~10GB di spazio reale su disco fisso:

Verificare che i dispositivi di loopback siano disponibili:

Supponendo che tutti i dispositivi di loopback siano disponibili, creare i dispositivi:

Il dispositivo è ora disponibile per essere utilizzato come ogni altro disco fisso nel sistema (e quindi è perfetto per i volumi fisici).

Risoluzione dei problemi
LVM ha alcune caratteristiche che già forniscono un certo livello di ridondanza. Tuttavia, ci sono situazioni dove è possibile ripristinare volumi fisici o volumi logici persi.

Utilità vgcfgrestore
In serie, ogni variazione del volume fisico LVM, di gruppo di volumi, o di volume logico, LVM2 crea un file di backup di metadata in. Questi files possono essere utilizzati per il recupero dopo una variazione accidentale (come per esempio la cancellazione del volume logico sbagliato). LVM mantiene anche una copia di backup del più recente metadata su. Questa copia può essere utilizzata per ripristinare i metadata di un disco sostitutivo, o riparare il metadata corrotto.

Per vedere quali membri del gruppo di volumi sono disponibili per il ripristino (output parziale per migliorare la leggibilità):

Recupero di un volume logico cancellato accidentalmente
Supponendo che il volume logico "lvm_raid1" sia stato rimosso accidentalmente dal gruppo di volumi "vg0", è possibile recuperarlo come segue:

Sostituire un volume fisico fallito
È possibile fare una vera "sostituzione" e ricreare il metadata nel nuovo volume fisico in modo da essere lo stesso del vecchio volume fisico:

La linea fondamentale qui è l'UUID "unknown device".

Questo ricrea il metadata del volume fisico, ma non il volume logico mancante o i dati del gruppo di volumi sul volume fisico.

Questo ora ricostruisce tutti i metadata mancanti nel volume fisico, includendo il volume logico e i data del gruppo di volume. Tuttavia non ripristina i dati, così che il mirror è fuori sincronia.

Questo risincronizzerà il mirror. E' funzionante con RAID 4, 5 e anche con il 6.

Disattivare un volume logico
È possibile disattivare un volume logico con il seguente comando:

Non è possibile montare il volume logico ovunque prima che esso sia riattivato:

Risorse esterne

 * LVM2 sourceware.org
 * LVM tldp.org
 * LVM2 Wiki redhat.com