Micromata BorgBackup-Butler =========================== Micromata GmbH, Kai Reinhard :toc: :toclevels: 4 Copyright (C) 2018-2021 ifdef::env-github,env-browser[:outfilesuffix: .adoc] == Examples === Borg script client [source,bash] ---- #!/bin/sh BORG_COMMAND=~/.borgbutler/bin/borg-macosx64-1.1.8 # Setting this, so the repo does not need to be given on the commandline: export BORG_REPO=ssh://horst@borgbackup.acme.priv:23/backups/myLaptop export BORG_RSH='ssh -i /home/horst/.ssh/borgbackup' # Setting this, so you won't be asked for your repository passphrase: # export BORG_PASSPHRASE='XYZl0ngandsecurepa_55_phrasea&&123' # or this to ask an external program to supply the passphrase: export BORG_PASSCOMMAND="cat /home/horst/.borg-passphrase" # Intialization: # 1. export BORG_PASSCOMMAND="cat /home/horst/.borg-passphrase" # 2. BORG_RSH='ssh -i /home/horst/.ssh/borgbackup' # 3. borg init --encryption=repokey ssh://horst@@borgbackup.acme.priv:23/backups/myLaptop case "$1" in break-lock) borg break-lock $BORG_REPO exit 1 ;; info) borg info $BORG_REPO exit 1 ;; create) echo Creating backup ;; *) echo "Usage: $0 {break-lock|create|info}" >&2 exit 1 ;; esac # some helpers and error handling: info() { printf "\n%s %s\n\n" "$( date )" "$*" >&2; } trap 'echo $( date ) Backup interrupted >&2; exit 2' INT TERM info "Starting backup" # Backup the most important directories into an archive named after # the machine this script is currently running on: $BORG_COMMAND create \ --filter AME \ --stats \ --progress \ --show-rc \ --compression lz4 \ --exclude-caches \ --exclude '/home/*/.cache/*' \ --exclude '/Users/*/.cache/*' \ --exclude '/var/cache/*' \ --exclude '/var/tmp/*' \ --exclude '*/Caches/*' \ --exclude '*/.m2/*' \ --exclude '/Users/horst/Library/*' \ --exclude '/Users/horst/Music/iTunes/iTunes\ Music/*' \ --exclude '/Users/horst/Backup/Archive' \ --exclude '/Users/horst/Downloads' \ ::'myLaptop-{now}' \ /home/horst \ backup_exit=$? info "Pruning repository" # Use the `prune` subcommand to maintain 7 daily, 4 weekly and 6 monthly # archives of THIS machine. The '{hostname}-' prefix is very important to # limit prune's operation to this machine's archives and not apply to # other machines' archives also: $BORG_COMMAND prune \ --list \ --prefix 'myLaptop-' \ --show-rc \ --keep-daily 7 \ --keep-weekly 4 \ --keep-monthly 6 \ prune_exit=$? # use highest exit code as global exit code global_exit=$(( backup_exit > prune_exit ? backup_exit : prune_exit )) if [ ${global_exit} -eq 1 ]; then info "Backup and/or Prune finished with a warning" fi if [ ${global_exit} -gt 1 ]; then info "Backup and/or Prune finished with an error" fi exit ${global_exit} ----