mirror of https://github.com/micromata/borgbackup-butler.git

Kai Reinhard
20.23.2021 314107f3a3a54921a448672d8066dea470ea60cc
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
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}
----