restic-tools/bin/backup

143 lines
2.9 KiB
Text
Raw Permalink Normal View History

2017-09-04 10:36:00 +02:00
#! /bin/bash
set -uo pipefail
display_usage() {
echo "Usage: $0 <repo> (local|monitor <host> <warning> <critical>|restic arguments)" >&2
}
2017-09-04 10:36:00 +02:00
if [ "$#" -lt 2 ]; then
display_usage
exit 1
fi
TARGET=$1
ACTION=$2
RESTIC=$(which restic)
CURL=$(which curl)
2017-09-04 10:36:00 +02:00
check_config() {
CONFIG=/etc/backup/$1.repo
if [ ! -f $CONFIG ]; then
echo "Repo config file $CONFIG not found!"
exit 1
else
set -a
source $CONFIG
2017-09-04 10:36:00 +02:00
set +a
fi
if [[ ! -x $RESTIC ]]; then
2017-09-04 10:36:00 +02:00
echo "Restic binary not found"
exit 1
2017-09-04 10:36:00 +02:00
fi
}
handle_params () {
. /etc/backup/local.config
2017-09-04 10:36:00 +02:00
if [ $2 == "local" ]; then
do_local_backup
elif [ $2 == "monitor" ]; then
do_monitor $@
else
shift 1
# define an empty default if RESTIC_ARGS is not set
RESTIC_ARGS=${RESTIC_ARGS:-""}
$RESTIC $RESTIC_ARGS $@
2017-09-04 10:36:00 +02:00
fi
}
do_local_backup () {
if [ ! -f /etc/backup/local.config ]; then
echo "local backup config file $/etc/backup/local.config not found!"
exit 1
fi
. /etc/backup/local.config
# define an empty default if BACKUP_ARGS is not set
BACKUP_ARGS=${BACKUP_ARGS:-""}
if [[ -x /etc/backup/local.pre ]]; then
/etc/backup/local.pre $TARGET
fi
$RESTIC --exclude-file /etc/backup/local.exclude backup --host $BACKUP_HOSTNAME $BACKUP_ARGS $BACKUP_DIR
2017-09-04 16:38:38 +02:00
if [[ -x /etc/backup/local.post ]]; then
/etc/backup/local.post $TARGET
fi
if [[ -n "${HEALTHCHECK_URL:-}" ]]; then
if [[ -x $CURL ]]; then
$CURL -fsS --retry 4 "$HEALTHCHECK_URL" > /dev/null
fi
2017-09-04 16:38:38 +02:00
fi
2017-09-04 10:36:00 +02:00
}
do_monitor () {
if [ $# -lt 5 ]; then
display_usage
exit 1;
fi
WARN=$4
CRIT=$5
# define an empty default if RESTIC_ARGS is not set
RESTIC_ARGS=${RESTIC_ARGS:-""}
SNAPS=`$RESTIC $RESTIC_ARGS snapshots --compact --no-lock -H $3`
2017-09-04 10:36:00 +02:00
# Get last line and parse into variables. Removes header and is empty when no snapshot exists for host
LAST=`sed 1,2d <<< $SNAPS | head -n -2 | tail -n 1`
COUNT=`tail -n 1 <<< $SNAPS | cut -d " " -f 1`
2017-09-04 10:36:00 +02:00
if [ ! $? -eq 0 ]; then
echo "WARNING - restic command returned an error"
2017-09-04 10:36:00 +02:00
exit 1;
fi
IFS=' ' read HASH DATE TIME HOST DIR <<< "$LAST"
if [ -z "$HASH" ]; then
2017-09-04 10:36:00 +02:00
echo "UNKNOWN - No snapshot found for $3"
exit 4;
fi
2017-09-04 10:36:00 +02:00
# Compute time difference since last snapshot
case $(uname -s) in
Darwin)
BACKUP_TST=$(date -j -f "%Y-%m-%d %H:%M:%S" "$DATE $TIME" "+%s")
;;
*)
BACKUP_TST=$(date -d "$DATE $TIME" +"%s" )
;;
esac
2017-09-04 10:36:00 +02:00
NOW_TST=$(date +%s)
DIFF_S=`expr $NOW_TST - $BACKUP_TST`
2017-09-04 10:36:00 +02:00
DIFF_H=`expr $DIFF_S / 3600`
MESSAGE="Last snapshot #$HASH ${DIFF_H}h ago|snapshots=$COUNT; age=$DIFF_H"
2017-09-04 10:36:00 +02:00
RET=0
RET_H="OK"
2017-09-04 10:36:00 +02:00
if [ $DIFF_H -lt $WARN ]; then
RET=0
2017-09-04 10:36:00 +02:00
RET_H="OK"
elif [ $DIFF_H -lt $CRIT ]; then
RET=1
RET_H="WARNING"
else
2017-09-04 10:36:00 +02:00
RET=2
RET_H="CRITICAL"
fi
echo "$RET_H - $MESSAGE"
return $RET
2017-09-04 10:36:00 +02:00
}
check_config $@
handle_params $@