Add a new backup script
This commit adds a backup script to backup all instances regularly. Fixes #11.
This commit is contained in:
parent
65a42f61e9
commit
21bd4f22c3
7 changed files with 115 additions and 17 deletions
|
|
@ -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
62
distillery/backup.sh
Normal 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 {} \;
|
||||
|
|
@ -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. "
|
||||
|
|
@ -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
|
||||
###
|
||||
|
|
|
|||
|
|
@ -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
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue