Files
wordpress_borg_backup/backup-Wordpress.sh
2019-12-19 20:06:38 +05:30

97 lines
3.4 KiB
Bash
Executable File

#!/bin/sh
# Create DB backup in the given location
# wp db export downloads/`date +%Y%m%d`_database.sql --add-drop-table --path=/var/www/upakhyana.com/htdocs/
# - Where to keep the db backups?
# Do Backup of the WP files + logfiles + Db Backup files
# - Borg - run it on lower priority with "nice"
# Compression? zlib?
# Pruning?
# Max size?
# Frequency?
# What needs to be excluded?
# Sync the backup to remote using Rclone
# How about backup filling up space?
# What if the server gets hacked - can he delete everything from remote location as well?
# So root - no good
[[ "$(id -u)" != "0" ]] && {
echo -e "ERROR: You must be root to run this script.\nPlease login as root and execute the script again."
exit 1
}
SCRIPT_NAME=wp_borg_backup
SCRIPT_VERSION=0.1
wp_src_dir=""
wp_log_dir=""
backup_dst_dir=""
borg_passphrase=""
storage_quota="5G" #if user provided - update this
project_name=""
TS=$(date '+%d_%m_%Y-%H_%M_%S')
LOGFILE=/tmp/"$SCRIPT_NAME"_v"$SCRIPT_VERSION"_"$TS".log
# Install "borgbackup" if NOT installed
if ! type borg 2>> "$LOGFILE" >&2; then
apt-get install -y borgbackup 2>> "$LOGFILE" >&2
fi
#If borg is running the same backup - quit
if (pidof -x borg > /dev/null) && $(pgrep -ac "$wp_src_dir") -gt 0 ; then
echo "${wp_src_dir} is being backed up from another process" | tee -a "$LOGFILE"
echo "This process will now exit" | tee -a "$LOGFILE"
exit 11
fi
# Backup the DB
if [[ -d ${backup_dst_dir}/DB ]]; then
mkdir ${backup_dst_dir}/DB 2>> "$LOGFILE" >&2
fi
# Install wp-cli if not installed
if ! type wp 2>> "$LOGFILE" >&2; then
echo -e "wp-cli not found on system. \nInstalling wp-cli" 2>> "$LOGFILE" >&2
wget https://raw.githubusercontent.com/wp-cli/builds/gh-pages/phar/wp-cli.phar -O /usr/local/bin/wp 2>> "$LOGFILE" >&2
chmod +x /usr/local/bin/wp 2>> "$LOGFILE" >&2
fi
# Backup WP database
wp db export ${backup_dst_dir}/DB/"$TS"_database.sql --add-drop-table --path=${wp_src_dir} 2>> "$LOGFILE" >&2
# If no passphrase provided and repo exists at the destination - Exit
if [[ ( -z "$borg_passphrase") && (-f "$backup_dst_dir"/config || -d "$backup_dst_dir"/WP || -d "$backup_dst_dir"/WP/config) ]]; then
echo -e "You did not provide passphrase for this existing backup.\nProcess will exit now." | tee -a "$LOGFILE"
exit 12
fi
# Auto generate passphrase if no repo exists
if [[ -z "$borg_passphrase" && ! -f "$backup_dst_dir"/config && ! -d "$backup_dst_dir"/WP && ! -d "$backup_dst_dir"/WP/config ]]; then
borg_passphrase=$(< /dev/urandom tr -cd 'a-zA-Z0-9~!@#$%^&*()_+-=' | head -c 20) # 20-character
mkdir "$backup_dst_dir"/WP 2>> "$LOGFILE" >&2
export BORG_NEW_PASSPHRASE="$borg_passphrase"
# Initalize the repo
borg init -v --encryption=repokey-blake2 --storage-quota "$storage_quota" "$backup_dst_dir"/WP
fi
# Peform the actual backup
export BORG_PASSPHRASE="$borg_passphrase"
borg create \
"$backup_dst_dir"/WP::{hostname}_"$project_name"_"$TS" \
"$wp_src_dir"
borg create \
--verbose \
--filter AMEsd \
--list \
--json \
--stats \
--show-rc \
--compression zstd \