Ceci est une ancienne révision du document !
Faire une sauvegarde avec zfs
zfs(8) va vous permettre de sauvegarder vos systèmes et données d'une machine à une autre très simplement.
Dans cet article S désigne le système à sauvegarder et D, le système qui va contenir la sauvegarde.
Que sauvegarder
Faites un cliché de votre système S:
$ zfs snap -r zroot@maintenant
Dans le cas présent, je fais un instantané de toute la hiérarchie qui se trouve sous le dataset zroot
.
En général, il s'agit de tout votre pool.
Pensez à nettoyer tout ce qui pourrait être mis en cache et qu'il n'est pas nécessaire de sauvegarder avant de lancer la procédure.
$ pkg clean -a
Par exemple, les paquets téléchargé, dans /usr/ports/distfiles
:
L'hôte
Préparez votre hôte D pour recevoir la sauvegarde.
$ zfs create zroot/BCK $ zfs create zroot/BCK/S $ zfs set canmount=off zroot/BCK/S
La dernière ligne vous assure que votre sauvegarde ne sera jamais remontée automatiquement, ce qui va éviter de sérieux problèmes si la sauvegarde contient des points de montage de la hiérarchie standard, hier(7). Ce qui est en général le cas.
Nous allons faire passer le flux de données au travers d'un tunnel ssh, nous allons avoir besoin:
- d'un utilisateur sans droits
root
; - que cet utilisateur puisse travailler sur le dataset cible.
$ zfs allow -u david create,mount,destroy,receive zroot/BCK/S
Sauvegarder
Depuis le système S, envoyer votre cliché vers la cible D:
$ zfs send -R zroot@maintenant | ssh -i my_id_rsa david@sauvegarde.D.net zfs recv -Fduv zroot/BCK/S
-F
va supprimer sur la cible les clichés qui ne sont plus sur la source.
Affinez et accélérer le transfert par
$ zfs send -c -D -R zroot@maintenant | ssh -i my_id_rsa david@sauvegarde.D.net zfs recv -Fduv zroot/BCK/S
-c
pour compresser ce qui peut l'être-D
pour utiliser la dé-duplication, c'est à dire n'envoyer qu'une fois les blocs qui sont identiques.
Sauvegarde incrémentale
Une fois le premier cliché sauvegardé, vous allez pourvoir utiliser la sauvegarde incrémentale.
C'est à dire, faire une sauvegarde à partir de deux clichés. Typiquement, entre le cliché le plus récent que vous avez pris sur la source S et le dernier que vous avez envoyé à l'hôte D, qui doit bien sûr toujours exister sur S.
Il suffit de donner ces deux clichés à send
derrière l'option -i
.
zfs send -c -D -i zroot/dataset@${REMOTE_ZLAST} zroot/dataset@${LOCAL_ZLAST} | ssh user@D zfs recv -Fdu zfs/${REMOTE_POOL}
${REMOTE_ZLAST}
, cliché le plus récent transféré sur D;${LOCAL_ZLAST}
, cliché le plus récent pris sur S.
Une fois transféré, vous pouvez supprimer le cliché ${REMOTE_ZLAST}
de S, ${LOCAL_ZLAST}
prenant sa place.
En cascade
L'option -r
(récursif) donnée à zfs send
va envoyer en cascade le dataset
parent ainsi que ses enfants.
Ça a un coté pratique, puisque vous n'aurez pas à définir un par un les éléments que vous voulez sauvegarder.
D'un autre coté, vous allez absolument tout sauvegarder, en particulier de nombreuses données dont vous n'aurez pas besoin ensuite, par exemple /usr/src
, /tmp
et une partie des enfants de /var
.
Par contre, si la machine contient des jails, vous allez sauvegarder non seulement ces dernières, mais aussi la base qui a servi à les construire.Sans parler de vos poudrières.
Bien entendu , Vous allez automatiser tout ça dans un script, n'est-ce pas 😉?
Ce qui rend le send
en cascade inutile.
Choisissez ceux que vous allez sauvegarder et intégrez les dans une boucle.
Nettoyer
Pour éviter de multiplier les clichés sur un hôte, effacer régulièrement, ou par script, les clichés les plus vieux:
$ zfs destroy -vr zroot@%vieux
Utilisé avec l'option -F
de receive
, la cible sera aussi nettoyée.