LVM (Italiano)

From ArchWiki
Revision as of 17:49, 12 February 2009 by Dav2dev (Talk | contribs) (Installazione)

Jump to: navigation, search


Introduzione

LVM (Logical Volume Manager) è una tecnologia che permette di creare dischi e partizioni "virtuali" a partire dai dispositivi di archiviazione presenti, ottenendo un sistema molto più flessibile del partizionamento classico dei dischi.

In LVM, la funzione della partizione è svolta dal Volume Logico (LV, Logical Volume). Ogni Volume Logico fa parte di un Gruppo di Volumi (VG, Volume Group), che sarebbe il dispositivo di archiviazione "virtuale" e può corrispondere a una partizione reale (chiamata Volume Fisico - Physical Volume, PV) del disco rigido o anche all'unione di diverse partizioni, anche su dischi rigidi distinti. Un disco rigido può per esempio avere 3 partizioni primarie usate con il metodo classico e una quarta partizione primaria marcata per essere usata da LVM. LVM vedrà quindi un Volume Fisico (PV) sul quale può creare un Gruppo di Volumi Logici (VG), e all'interno di questo creare i Volumi Logici (LV) da formattare e usare per archiviare file.

LVM permette una gestione più flessibile dello spazio di memoria. Per esempio, è possibile:

  • Usare diversi dischi rigidi come se fossero uno solo (VG)
  • Distribuire le "partizioni" (LV) su più dischi.
  • Ridimensionare/creare/eliminare a piacere le "partizioni" (LV) e i "dischi" (VG), senza preoccuparsi della posizione dei LV all'interno dei VG.
  • Ridimensionare/creare/eliminare partizioni (LV) e dischi (VG) online (i filesystem su di essi vanno ridimensionati a parte, anche se non tutti permettono di farlo online)
  • Usare nomi arbitrari per i VG e i LV
  • Creare LV piccoli e ingrandirli in seguito se necessario
  • ...

Example:

Physical disks
                
  Disk1 (/dev/sda):
     _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _
    |Partition1 50GB (Physical volume) |Partition2 80GB (Physical volume)     |
    |/dev/sda1                         |/dev/sda2                             |
    |_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ |_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ |
                                  
  Disk2 (/dev/sdb):
     _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _
    |Partition1 120GB (Physical volume)                 |
    |/dev/sdb1                                          |
    | _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ __ _ _|
LVM logical volumes

  Volume Group1 (/dev/MyStorage/ = /dev/sda1 + /dev/sda2 + /dev/sdb1):
     _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
    |Logical volume1 15GB  |Logical volume2 35GB      |Logical volume3 200GB               |
    |/dev/MyStorage/rootvol|/dev/MyStorage/homevol    |/dev/MyStorage/mediavol             |
    |_ _ _ _ _ _ _ _ _ _ _ |_ _ _ _ _ _ _ _ _ _ _ _ _ |_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ |

To sum it all up: With LVM you can use all your storage space as one big disk (volume group) and have more flexibility over your partitions (logical volumes).

Installazione

Il sistema ArchLinux di base possiede già il necessario per sfruttare LVM.

Per prima cosa bisogna caricare il modulo seguente:

# modprobe dm-mod

Partizionare i dischi

Creare le partizioni da dedicare a LVM. Il tipo (type nel menu di cfdisk) di partizione da scegliere è 'Linux LVM', che ha codice '8E'.

Creare i Volumi Fisici (PV)

Un Volume fisico è una partizione inizializzata per essere usata da LVM mediante il comando:

# pvcreate /dev/sda2

ripetere il comando per tutte le partizioni che si intende usare con LVM. Per visualizzare i Volumi Fisici attualmente presenti:

# pvdisplay

Creare i Gruppi di Volumi (VG)

Un Gruppo di Volumi (VG) è un nuovo dispositivo di archiviazione "virtuale" formato da uno o più Volumi Fisici (PV). Si inizia creando un VG su un PV e poi si aggiungono altri PV allo stesso VG, in modo da aumentarne la capacità:

# vgcreate VolGroup00 /dev/sda2
# vgextend VolGroup00 /dev/sdb1

Al posto di VolGroup00 si può usareun nome qualunque.

Per visualizzare i VG creati e la loro composizione:

# vgdisplay

Creare i Volumi Logici (LV)

Un Volume Logico (LV) è l'omologo della partizione, quindi al suo interno verrà creato un filesystem e salvati file. Per creare un LV si usa il seguente comando:

# lvcreate VolGroup00 -L 10G -n lvolhome

Il nuovo LV ha nome lvolhome (ma si può usare un nome a piacere), è grande 10GB, si trova sul VG VolGroup00 e vi si può accedere tramite il percorso /dev/VolGroup00/lvolhome o anche /dev/mapper/Volgroup00-lvolhome.

Per visualizzare tutti gli LV presenti:

# lvdisplay

Attenzione: per creare un LV da usare come swap, usare il comando:

# lvcreate -C y -L 10G VolGroup00 -n lvolswap

L'opzione -C y serve ad assegnare dello spazio contiguo al LV, in modo da velocizzarne l'accesso.

Suggerimento: per creare un LV usando tutto lo spazio rimasto nel VG, usare:

# lvcreate -l +100%FREE VolGroup00 -n lvolmedia

Formattare e montare i Volumi Logici (LV)

I file di dispositivo relativi ai Volumi Logici (LV) creati sono disponibili in /dev/NomeDelGruppoDiVolumi e anche in /dev/mapper/. Se non sono presenti, provare a dare i seguenti comandi:

# modprobe dm-mod
# vgchange -ay

A questo punto è possibile creare i filesystem sugli LV e montarli come normali partizioni:

# mkfs.ext3 /dev/VolGroup00/lvolhome
# mount -t ext3 /dev/VolGroup00/lvolhome /home


Installare ArchLinux su un Volume Logico

È possibile installare ArchLinux su dei Volumi Logici (LV), basta seguire alcune precauzioni:

  1. Dal momento che GRUB (0.9x) non supporta LVM, bisogna creare una partizione a parte per la directory /boot, la configurazione minima sarà: 1 partizione primaria di tipo «Linux» (codice 83) per "/boot", e una partizione di tipo «Linux LVM» (codice 8E) con all'interno un Volume Logico per la directory radice "/". In alternativa è possibile usare GRUB2 (1.9x) o Lilo, che sono compatibili con LVM, e partizionare il disco a piacere.
  2. Le partizioni di tipo «Linux LVM» (codice 8E) NON vanno usate per i mountpoints. Usare invece i Volumi Logici che verranno presentati insieme alle partizioni (es: /dev/mapper/Volgroup00-lvolhome). (Set Filesystem Mountpoints)
  3. Assicurarsi di avere la riga USELVM="yes" in /etc/rc.conf, se la directory radice del sistema si trova su un Volume Logico. (Configure System)
  4. Aggiungere lvm2 alla lista HOOKS in /etc/mkinitcpio.conf subito prima di filesystems così il kernel sarà in grado di accedere ai Volumi Logici in avvio del sistema. (Configure System)
  5. Assicurarsi che in /boot/grub/menu.lst l'opzione "root=" sia corretta: (Install Bootloader)
...
# (0) Arch Linux
title  Arch Linux
root   (hd0,0)
kernel /vmlinuz26 root=/dev/mapper/VolGroup00-lvolroot resume=/dev/mapper/VolGroup00-lvolswap ro
initrd /kernel26.img
...

Se si usa Lilo, controllare invece nel file /etc/lilo.conf:

image=/boot/vmlinuz26
       label=arch
       append="root=/dev/mapper/VolGroup00-lvolroot resume=/dev/mapper/VolGroup00-lvolswap ro"
       initrd=/boot/kernel26.img

Configuration

Grow logical volume

To grow a logical volume you first need to grow the logical volume and then the filesystem to use the newly created free space. Let's say we have a logical volume of 15GB with ext3 on it and we want to grow it to 20G. We need to do the following steps:

# lvextend -L 20G VolGroup00/lvolhome (or lvextend -L +5G VolGroup00/lvolhome)
# resize2fs /dev/VolGroup00/lvolhome

You may use lvresize insted of lvextend.

Attention: Not all filesystem support growing without loss of data and/or growing online.

Information: If you don't resize your filesystem, you will still have a volume with the same size as before (volume will be bigger but partly unused).

Hint: If you want to fill all the free space on a volume group use the next command:

# lvextend -l +100%FREE VolGroup00/lvolhome

Shrink logical volume

Because your filesystem is probably as big as logical volume it resides on, you need to shrink the filesystem first and then shrink the logical volume. Depending on your filesystem, you may need to unmount it first. Let's say we have a logical volume of 15GB with ext3 on it and we want to shrink it to 10G. We need to do the following steps:

# resize2fs /dev/VolGroup00/lvolhome 9G
# lvreduce -L 10G VolGroup00/lvolhome (or lvreduce -L -5G VolGroup00/lvolhome)
# resize2fs /dev/VolGroup00/lvolhome

Here we shrunk the filesystem more than needed so that when we shrunk the logical volume we didn't accidentally cut of the end of the filesystem. After that we normally grow the filesystem to fill all free space left on logical volume. You may use lvresize insted of lvreduce.

Attention: Don't reduce the filesystem size to less than it is used by data on it or you can lose your data.

Attention: Not all filesystems support shrinking without loss of data and/or shrinking online.

Attention: It is better to reduce the filesystem to lower size than the logical volume, so that after a resizing logical volume, we don't accidentally cut off some data from the end of the filesystem.

Add partition to a volume group

To add partition to you volume group you must first make its type 'Linux LVM' (for example with cfdisk). Then you need to create physical volume on it and extend volume group over it:

# pvcreate /dev/sdb1
# vgextend VolGroup00 /dev/sdb1

Now you have free space in your volume group that can be used by logical volumes in this group.

Information: You can add partitions from any disks to volume groups.

Remove partition from a volume group

All of the data on that partition needs to be moved to another partition. Fortunately, lvm makes this easy:

# pvmove /dev/mapper/myvg-mypv

If you want to have the data on a specific physical volume, specify that as the second argument to pvmove.

Then the physical volume needs to be removed from the volume group:

# vgreduce myVg /dev/mapper/myvg-mypv

Or remove all empty physical volumes:

# vgreduce --all vg0

And lastly, if you want to use the partition for something else, and want to avoid lvm thinking that the partition is a physical volume:

# pvremove /dev/mapper/myvg-removedpv

Snapshots

Introduction

LVM allows you to take a snapshot of your system in a much more efficient way than a traditional backup. It does this efficiently by using a COW (copy-on-write) policy. The initial snapshot you take simply contains hard-links to the inodes of your actual data. So long as your data remains unchanged, the snapshot merely contains there inode pointers and not the data itself. Whenever you modify a file or directory that the snapshot points to, LVM automatically clones the data, the old copy referenced by the snapshot, and the new copy referenced by your active system. Thus, you can snapshot a system with 35GB of data using just 2GB of free space so long as you modify less than 2GB (on both the original and snapshot).

Configuration

You create snapshot logical volumes just like normal ones.

# lvcreate --size 100M --snapshot --name snap01 /dev/mapper/vg0-pv

With that volume, you may modify less than 100M of data, before the snapshot volume fills up.

Todo: scripts to automate snapshots of root before updates, to rollback... updating menu.lst to boot snapshots (separate article?)

snapshots are primarily used to provide a frozen copy of a filesystem to make backups; a backup taking two hours provides a more consistent image of the filesystem than directly backing up the partition.

Troubleshooting

LVM commands don't work

try preceeding commands with lvm like this:

# lvm pvdisplay

Tips & Tricks

Todo

More Resources

Other LVM articles on the Archwiki:

External resources: