2021-01-21 13:58:30 -08:00
|
|
|
#!/bin/bash
|
|
|
|
#
|
|
|
|
# Bashup - A set of bash scripts for managing backups.
|
|
|
|
# https://git.stack-source.com/msb/bashup
|
|
|
|
# MIT License Copyright (c) 2021 Matthew Saunders Brown
|
|
|
|
|
2021-04-22 15:03:50 -07:00
|
|
|
# load include file
|
|
|
|
source $(dirname $0)/bashup.sh
|
2021-01-21 13:58:30 -08:00
|
|
|
|
2021-04-23 09:49:36 -07:00
|
|
|
bashup::set-retention_array
|
2021-01-21 13:58:30 -08:00
|
|
|
|
|
|
|
# create backup for today
|
|
|
|
if [[ " ${retention_array[@]} " =~ " ${today} " ]]; then
|
|
|
|
|
|
|
|
# create backup (date) dir if it doesn't already exist
|
|
|
|
if [ ! -d "$backup_storage_dir/$today" ]; then
|
|
|
|
|
|
|
|
mkdir $backup_storage_dir/$today
|
|
|
|
|
|
|
|
fi
|
|
|
|
|
|
|
|
# only proceed if mysql has not already been backed up
|
|
|
|
if [[ ! -d $backup_storage_dir/$today/mysql ]]; then
|
|
|
|
|
|
|
|
mkdir $backup_storage_dir/$today/mysql
|
|
|
|
mysqladmin --defaults-extra-file=$defaults_extra_file refresh
|
|
|
|
|
|
|
|
# create array of all existing databases
|
|
|
|
databases=($(mysql --defaults-extra-file=$defaults_extra_file -E -e 'show databases;'|grep : |awk '{ print $2 }' |tr '\n' ' '));
|
|
|
|
|
|
|
|
for database in "${databases[@]}"; do
|
|
|
|
|
|
|
|
if [[ " ${exclusions[@]} " =~ " ${database} " ]]; then
|
|
|
|
# do nothing, db is in exclusions array
|
|
|
|
one=1;
|
|
|
|
else
|
|
|
|
mysqldump --defaults-extra-file=$defaults_extra_file --opt --quote-names --events --databases $database | gzip > $backup_storage_dir/$today/mysql/$database.sql.gz
|
|
|
|
fi
|
|
|
|
|
|
|
|
done
|
|
|
|
|
|
|
|
fi
|
|
|
|
|
|
|
|
fi
|
|
|
|
|
2021-04-23 12:52:28 -07:00
|
|
|
bashup::remove_expired_backups mysql
|
2021-04-22 15:03:50 -07:00
|
|
|
bashup::unmount_storage_dir
|
2021-01-21 13:58:30 -08:00
|
|
|
|
2021-04-22 15:03:50 -07:00
|
|
|
exit 0
|