Add a new backup script

This commit adds a backup script to backup all instances regularly.
Fixes #11.
This commit is contained in:
Tom Wiesing 2020-07-10 11:50:33 +02:00
parent 65a42f61e9
commit 21bd4f22c3
No known key found for this signature in database
GPG key ID: DC1F29F2BC78AB15
7 changed files with 115 additions and 17 deletions

View file

@ -16,6 +16,9 @@ SELF_REDIRECT=
# This email address can be configured here.
CERTBOT_EMAIL=
# The maximum age (in days) for backups to be kept.
# Backups older than this will be removed when a new backup is made.
MAX_BACKUP_AGE=30
# Each Drupal instance requires a corresponding system user, database users and databases.

62
distillery/backup.sh Normal file
View file

@ -0,0 +1,62 @@
#!/bin/bash
set -e
# read the lib/shared.sh and read the slug argument.
DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" >/dev/null 2>&1 && pwd )"
cd "$DIR"
source "$DIR/lib/lib.sh"
log_info " => Starting backup process. This might take a while. "
wait_for_sql
BACKUP_SLUG="$(date +%Y%m%dT%H%M%S)-$(randompw)"
BACKUP_INSTANCE_DIR="$DEPLOY_BACKUP_INPROGRESS_DIR/$BACKUP_SLUG"
BACKUP_FINAL_FILE="$DEPLOY_BACKUP_FINAL_DIR/$BACKUP_SLUG.tar.gz"
BACKUP_SQL_FILE="$BACKUP_INSTANCE_DIR/backup.sql"
BACKUP_TRIPLESTORE_DIR="$BACKUP_INSTANCE_DIR/triplestore"
BACKUP_TRIPLESTORE_SYSTEM="$BACKUP_TRIPLESTORE_DIR/system.nq"
BACKUP_FILESYSTEM_DIR="$BACKUP_INSTANCE_DIR/instances"
# create the backup directories
log_info " => Making '$BACKUP_INSTANCE_DIR'"
mkdir -p "$BACKUP_INSTANCE_DIR"
mkdir -p "$DEPLOY_BACKUP_FINAL_DIR"
# backup the configuration
cp "$CONFIG_FILE" "$BACKUP_INSTANCE_DIR/.env"
# Backup the sql backup
log_info " => Backing up the SQL database"
dockerized_mysqldump --all-databases > "$BACKUP_SQL_FILE"
# Backup the triplestore system
log_info " => Backing up Triplestore System"
mkdir -p "$BACKUP_TRIPLESTORE_DIR"
curl -X GET -H "Accept:application/n-quads" "http://localhost:7200/repositories/SYSTEM/statements?infer=false" > "$BACKUP_TRIPLESTORE_SYSTEM"
# backup individual repos
for REPO in `grep -oP '(?<=#repositoryID> ")[^"]+' $BACKUP_TRIPLESTORE_SYSTEM`; do
log_info " => Backing up Triplestore Repository '$REPO'"
curl -X GET -H "Accept:application/n-quads" "http://localhost:7200/repositories/$REPO/statements?infer=false" > "$BACKUP_TRIPLESTORE_DIR/repo_$REPO.nq"
done
# backup the filesystem
log_info " => Backing up instance filesystem"
cp -rpT "$DEPLOY_INSTANCES_DIR" "$BACKUP_FILESYSTEM_DIR"
# Package the backup into a .tar.gz
log_info " => Packaging '$BACKUP_FINAL_FILE'"
pushd "$BACKUP_INSTANCE_DIR" > /dev/null
tar --totals --checkpoint=10000 -zcf "$BACKUP_FINAL_FILE" .
popd > /dev/null
# Clean up the unpacked backup
log_info " => Cleaning up '$BACKUP_INSTANCE_DIR'"
rm -rf "$BACKUP_INSTANCE_DIR"
log_info " => Removing backups older than $MAX_BACKUP_AGE days"
find "$DEPLOY_BACKUP_FINAL_DIR" -type f -mtime "+$MAX_BACKUP_AGE" -print -exec rm -f {} \;

View file

@ -159,6 +159,13 @@ if ! is_valid_number "$PASSWORD_LENGTH"; then
exit 1;
fi
# The 'MAX_BACKUP_AGE' variable must be a valid number.
if ! is_valid_number "$MAX_BACKUP_AGE"; then
log_error "Variable 'MAX_BACKUP_AGE' is missing or not a valid number. ";
log_info "Please verify that it is set correctly in '.env'. ";
exit 1;
fi
# The 'CERTBOT_EMAIL' variable should either be empty or a valid email
if [ -n "$SELF_REDIRECT" ]; then
if ! is_valid_https_url "$SELF_REDIRECT"; then
@ -178,5 +185,9 @@ DEPLOY_TRIPLESTORE_DIR="$DEPLOY_ROOT/core/triplestore"
DEPLOY_SQL_DIR="$DEPLOY_ROOT/core/sql"
DEPLOY_INSTANCES_DIR="$DEPLOY_ROOT/instances"
DEPLOY_BACKUP_DIR="$DEPLOY_ROOT/backups"
DEPLOY_BACKUP_INPROGRESS_DIR="$DEPLOY_BACKUP_DIR/inprogress"
DEPLOY_BACKUP_FINAL_DIR="$DEPLOY_BACKUP_DIR/final"
log_ok "Read and validated configuration file. "

View file

@ -41,7 +41,7 @@ function dockerized_mysql() {
return $retval
}
# 'dockerized_mysql' runs an sql command in the sql docker container interactively
# 'dockerized_mysql_interactive' runs an sql command in the sql docker container interactively
function dockerized_mysql_interactive() {
pushd "$DEPLOY_SQL_DIR" > /dev/null
docker exec -ti `docker-compose ps -q sql` mysql "$@"
@ -50,6 +50,15 @@ function dockerized_mysql_interactive() {
return $retval
}
# 'dockerized_mysqldump' runs a mysqldump command
function dockerized_mysqldump() {
pushd "$DEPLOY_SQL_DIR" > /dev/null
docker exec -i `docker-compose ps -q sql` mysqldump "$@"
retval=$?
popd > /dev/null
return $retval
}
###
### Bookkeeping sql
###

View file

@ -51,6 +51,8 @@ mkdir -p "$DEPLOY_WEB_DIR"
mkdir -p "$DEPLOY_SELF_DIR"
mkdir -p "$DEPLOY_TRIPLESTORE_DIR"
mkdir -p "$DEPLOY_SQL_DIR"
mkdir -p "$DEPLOY_BACKUP_INPROGRESS_DIR"
mkdir -p "$DEPLOY_BACKUP_FINAL_DIR"
log_info "=> Creating 'distillery' network"
docker network create distillery || true