Ceci est une ancienne révision du document !
J'utilise BorgBackup et Borgmatic pour m'occuper de mes sauvegardes.
Pour faire des sauvegardes manuellement, on peut utiliser borg.
Première étape, créer un dépôt de sauvegarde, par exemple après avoir monté un disque dur externe, vierge sur /backup :
borg init --encryption=none /backup
On peut évidemment chiffrer comme on veut; voir la doc pour ça.
On utilise la commande borg create pour ça :
[sudo] borg create --progress --stats [--rsh "ssh -p 2222" eorn@backup.goe.land:]/backup::masauvegarde-2020-03-20 /dossier/à/sauvegarder
Les parties [entre crochets] sont optionnels. En l'occurrence, l'option –rsh et les informations de connexion (eorn@backup.goe.land:) ne sont utiles que si on veut faire une sauvegarde sur un serveur distant.
Infos :
[sudo] borg infos /backup
Liste des sauvardes dans le dépôt :
[sudo borg list /backup
Il existe une surcouche à borg pour l'automatisation : borgmatic, qui a besoin d'un fichier de configuration dont voilà un exemple (rangé, chez moi, dans /srv/config/borg/config.yaml) :
location:
source_directories:
- /srv/apps/
repositories:
- borg@backup.goe.land:/backup
#exclude_patterns:
#- "*/*/db"
storage:
encryption_passcommand: "cat /srv/config/borg/passphrase"
compression: lz4
ssh_command: ssh -p 2222 -i /srv/config/borg/id_rsa
retention:
# Keep all archives within this time interval.
keep_within: 24H
# Number of daily archives to keep.
keep_daily: 7
# Number of weekly archives to keep.
keep_weekly: 4
# Number of monthly archives to keep.
keep_monthly: 6
consistency:
checks:
- disabled
# - repository
# - archives
Pour que cela fonctionne, j'ai créé un utilisateur borg sur ma machine de backup. Les informations pour la connexion ssh sont importantes, notamment la clé de connexion (id_rsa).
Pour avoir les info et liste des sauvegardes :
[sudo] borgmatic info -c /srv/config/borg/config.yaml [sudo] borgmatic list -c /srv/config/borg/config.yaml
Il faut pour cela utiliser les hooks dans le fichier de configuration.