Ceci est une ancienne révision du document !
Restic
Restic est un logiciel libre de sauvegarde qui offre toutes les fonctionnalités qu'on attend d'un logiciel de sauvegarde moderne : incrémentation1), chiffrement2), compression, déduplication3), etc.
Il permet de sauvegarder sur :
- un système de fichiers local
- OpenStack Swift
- Amazon S3
- BackBlaze B2
- Microsoft Azure Blob Storage
- Google Cloud Storage
- … et surtout sur tout ce que supporte Rclone, ce qui le rend compatible avec à peu près tout ce qui existe en terme de stockage, local ou distant, avec les meilleures performances possibles dans chaque situation :
- SMB / CIFS (partages locaux, Windows, Linux ou MacOS)
- OVH
- Synology C2 Object Storage
- Dropbox
- Proton Drive
- Internet Archive
- put.io
- etc.
Il s'utilise initialement en ligne de commande mais il existe diverses interfaces graphiques.
Il est relativement proche de Borg Backup d'un point de vue utilisation et performances, mais ne nécessite aucun logiciel côté dépôt (serveur), ce qui le rend particulièrement versatile. Il utilise aussi son propre format de fichier ce qui a l'inconvénient de ne pas rendre les fichiers stockés dans les dépôts accessibles avec n'importe quel outil, mais qui a aussi et surtout l'avantage de permettre le chiffrement, la compression, la déduplication, et la sauvegarde des permissions et dates des fichiers quel que soit le système de fichier sous-jacent ou le protocole d'échange utilisé.
Installation
Restic est disponible dans les dépôts officiels d'Ubuntu.
Pour l'installer il suffit donc d'installer le paquet restic.
Utilisation
Restic ne s'utilise qu'en ligne de commande, et ne propose pas directement de configuration.
On peut tout de même automatiser son utilisation en configurant des tâches systemd ou cron
Il existe aussi de nombreux wrappers qui permettent d'étendre les fonctionnalités de restic, par exemple justement en implémentant des fichiers de configuration pour faciliter son utilisation et automatiser les sauvegardes.
Dans le cadre de l'utilisation native de restic, on peut afficher la liste des commandes disponibles en tapant simplement restic
dans un terminal.
Restic permet de réaliser toutes sortes d'opérations mais on utilisera principalement init
la première configuration, puis régulièrement la commande backup
pour déclencher les sauvegardes (ou instantanés / snapshots).
Le paramètre -r
(ou --repo
en version longue) est très important : il permet de spécifier le dépôt (Repository en anglais) sur lequel on souhaite travailler.
Voir aussi (en) le guide d'utilisation, avec des instructions détaillées pour chaque fournisseur.
Initialisation
Pour commencer à utiliser restic il faut en premier lieu initialiser un dépôt avec la commande restic init
. C'est sur celui-ci qu'on effectuera les sauvegardes. Sur le dépôts les sauvegardes sont organisées par chemin local (celui des données qu'on sauvegarde, sur la machine locale) et nom d'hôte (le nom de la machine locale). On peut donc sauvegarder plusieurs fois un chemin similaire depuis différentes machines sur un même dépôt sans risque de tout mélanger.
Entrez la commande suivante dans un terminal :
restic -r sftp:serveur:/chemin/restic-repo init
Adaptez sftp:serveur:/chemin/restic-repo
selon votre solution de stockage distant :
sftp:
selon le protocole choisi, ou rclone:
pour un dépôt rclone, puis serveur:
pour le nom d'hôte.
Sauvegarde
C'est la commande restic backup
qui permet de délencher une sauvegarde.
En ligne de commande, restic s'utilise un peu comme rsync ou rClone.
restic -r sftp:serveur:/chemin/restic-repo backup /chemin
Commande à adapter comme init
précédemment :
-r
pour spécifier le dépôt sur lequel on souhaite travailler.- Le
/chemin
est celui du répertoire à sauvegarder. - On peut utiliser l'option
--exclude
pour exclure certains fichiers ou répertoires - et l'option
--dry-run
pour lancer un test sans effectuer réellement la sauvegarde.
La première fois qu'on lance cette commande, l'intégralité des données et compressée et sauvegardée. Par la suite avec la même commande on ne transfère que les données qui ont été modifiées, c'est donc beaucoup plus rapide.
Lister les sauvegardes
La commande snapshots
permet de lister les instantanés :
restic -r sftp:serveur:/chemin/restic-repo snapshots
Cette commande retourne un tableau dont la première colonne affiche l'identifiant de chaque instantané.
Restauration
La commande restic restore
permet de restaurer n'importe quel instantané précis.
restic -r sftp:serveur:/chemin/restic-repo restore identifiant_instantané --target /chemin
- L'
identifiant_instantané
est un numéro à 8 chiffres hexadécimaux, récupérés en listant les sauvegardes à l'étape précédente. - Le
/chemin
n'est ici pas forcément celui du contenu sauvegardé, mais celui vers lequel on veut restaurer la sauvegarde.
On peut ainsi restaurer n'importe quelle sauvegarde à l'emplacement de son choix.
Interfaces graphiques
Il existe de nombreuses interfaces graphiques permettant d'utiliser et d'explorer facilement les dépôts restic ;
- Restic Browser (GTK) permet d'explorer de restaurer les instantanés, ou de télécharger les répertoires en fichiers qui s'y trouvent de son choix.
- resticterm : une interface graphique en terminal (particulièrement pratique pour les serveurs ou les machines distantes).
- Backrest est une application web très complète, qui permet d'automatiser les sauvegardes, gérer dépôts, instantanés et fichiers sauvegardés, etc. depuis un navigateur (donc aussi particulièrement pratique pour les serveurs ou les machines distantes). Son installation peut s'avérer technique, c'est pourquoi il est recommandé d'utiliser l'image docker.
Voir cette liste plus complète.
Wrappers
Les wrappers4) permettent d'étendre les fonctionnalités de restic en l'utilisant comme "moteur" sous-jacent plus ou moins visible.
- Resticprofile permet de créer un fichier de configuration pour faciliter l'usage de la ligne de commande avec restic. La documentation n'existe malheureusement aussi qu'en anglais. resticprofile permet aussi de programmer très facilement des sauvegardes récurrentes aux moments de son choix (en utilisant systemd en arrière plan, ou cron dans le cas étonnant ou celui-ci ne serait pas disponible).
- Autorestic propose à peu près les mêmes fonctionnalités que resticprofile, mais de manière un peu plus directive (avoir moins de choix à disposition peut aussi permettre de simplifier la documentation) et facilite en plus la gestion de dépôts multiples (par ex. pour sauvegarder sur un disque dur en même temps que sur le cloud).
Voir aussi cette liste plus complète.