aboutsummaryrefslogtreecommitdiff
path: root/templates/borg.sh.erb
blob: 3eddd879c607fbab308e7f3fdba1ad05daf93963 (plain)
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
#!/bin/sh
# Adapted from https://borgbackup.readthedocs.io/en/stable/quickstart.html#automating-backups

export SSH_SERVER="<%= @user %>@<%= @host %>"
export SSH_PORT="<%= @port %>"

export HOSTNAME=`cat /etc/hostname`

# Setting this, so the repo does not need to be given on the commandline:
export BORG_REPO=ssh://$SSH_SERVER:$SSH_PORT//var/backups/remote/$HOSTNAME/borg

# Setting this, so you won't be asked for your repository passphrase:
export BORG_PASSPHRASE='<%= @password %>'
# or this to ask an external program to supply the passphrase:
#export BORG_PASSCOMMAND='pass show backup'

# some helpers and error handling:
#info() { printf "\n%s %s\n\n" "$( date )" "$*" >&2; }
trap 'info $( date ) Backup interrupted >&2; exit 2' INT TERM

# Check
if [ "$1" == "--check" ]; then
  borg list
  exit $?
fi

# Initialize
if ! ssh $SSH_SERVER -p $SSH_PORT test -f /var/backups/remote/$HOSTNAME/borg/config; then
	info "Initializing borg repository at ssh://$SSH_SERVER:$SSH_PORT//var/backups/remote/$HOSTNAME/borg..."
  borg init --encryption=<%= @encryption %> ssh://$SSH_SERVER:$SSH_PORT//var/backups/remote/$HOSTNAME/borg

	init_exit=$?

	if [ "$init_exit" != "0" ]; then
		fatal "Error initializing repository"
	fi
fi

# Backup the most important directories into an archive named after
# the machine this script is currently running on:

info "Starting backup..."

borg create                                \
	--verbose                          \
	--filter AME                       \
	--list                             \
	--stats                            \
	--show-rc                          \
	--compression lz4                  \
	--exclude-caches                   \
	--exclude '/home/*/.cache/*'       \
	--exclude '/var/cache/*'           \
	--exclude '/var/tmp/*'             \
  --exclude '/var/backups/remote'    \
  --exclude '/var/backups/duplicity' \
  --exclude '/var/backups/restore'   \
  --exclude '/var/cache'             \
  --exclude '/var/vservers'          \
  --exclude '/var/chroot'            \
  --exclude '/root/.cache'           \
  --exclude '/var/lib/dpkg'          \
  --exclude '/var/lib/apt'           \
  --exclude '/var/lib/aptitude'      \
  --exclude '/var/sites/backups'     \
  --exclude '/var/data/crypt'        \
  --exclude '/var/data/backups'      \
  --exclude '/var/data/cache'        \
	::'{hostname}-{now}'               \
	/etc                               \
	/home                              \
	/root                              \
	/var                               \

	backup_exit=$?

if [ "$backup_exit" != "0" ]; then
	fatal "Error creating snapshot"
fi

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 prune                           \
	--list                             \
	--prefix '{hostname}-'             \
	--show-rc                          \
  --keep-daily    <%= @keepdaily %>   \
  --keep-weekly   <%= @keepweekly %>  \
  --keep-monthly  <%= @keepmonthly %> \

	prune_exit=$?

if [ "$prune_exit" != "0" ]; then
	fatal "Error pruning repository"
fi

# 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}