f7168620ae
This patch set fixes the calculation of how long a database backup has be taken. In the existing code, the time difference is rounded to days, even a second less than 4 days will be rounded to 3 days. This effectively allows archives to be kept for one additional day. The new calculation and comparison is based on seconds. Change-Id: I5547e923538ddb83f409b1e7df936baf664e717a
117 lines
3.3 KiB
Smarty
117 lines
3.3 KiB
Smarty
#!/bin/bash
|
|
|
|
# Copyright 2018 The Openstack-Helm Authors.
|
|
#
|
|
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
|
# not use this file except in compliance with the License. You may obtain
|
|
# a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
# License for the specific language governing permissions and limitations
|
|
# under the License.
|
|
set -x
|
|
BACKUPS_DIR=${MARIADB_BACKUP_BASE_DIR}/db/${MARIADB_POD_NAMESPACE}/mariadb/current
|
|
ARCHIVE_DIR=${MARIADB_BACKUP_BASE_DIR}/db/${MARIADB_POD_NAMESPACE}/mariadb/archive
|
|
|
|
MYSQL="mysql \
|
|
--defaults-file=/etc/mysql/admin_user.cnf \
|
|
--connect-timeout 10"
|
|
|
|
MYSQLDUMP="mysqldump \
|
|
--defaults-file=/etc/mysql/admin_user.cnf"
|
|
|
|
seconds_difference() {
|
|
archive_date=$( date --date="$1" +%s )
|
|
if [ "$?" -ne 0 ]
|
|
then
|
|
second_delta=0
|
|
fi
|
|
current_date=$( date +%s )
|
|
second_delta=$(($current_date-$archive_date))
|
|
if [ "$second_delta" -lt 0 ]
|
|
then
|
|
second_delta=0
|
|
fi
|
|
echo $second_delta
|
|
}
|
|
|
|
DBNAME=( $($MYSQL --silent --skip-column-names -e \
|
|
"show databases;" | \
|
|
egrep -vi 'information_schema|performance_schema|mysql') )
|
|
|
|
#check if there is a database to backup, otherwise exit
|
|
if [[ -z "${DBNAME// }" ]]
|
|
then
|
|
echo "There is no database to backup"
|
|
exit 0
|
|
fi
|
|
|
|
#Create archive and backup directories.
|
|
mkdir -p $BACKUPS_DIR $ARCHIVE_DIR
|
|
|
|
#Create a list of Databases
|
|
printf "%s\n" "${DBNAME[@]}" > $BACKUPS_DIR/db.list
|
|
|
|
#Retrieve and create the GRANT files per DB
|
|
for db in "${DBNAME[@]}"
|
|
do
|
|
echo $($MYSQL --skip-column-names -e "select concat('show grants for ',user,';') \
|
|
from mysql.db where ucase(db)=ucase('$db');") | \
|
|
$MYSQL --silent --skip-column-names 2>grant_err.log > $BACKUPS_DIR/${db}_grant.sql
|
|
if [ "$?" -eq 0 ]
|
|
then
|
|
sed -i 's/$/;/' $BACKUPS_DIR/${db}_grant.sql
|
|
else
|
|
cat grant_err.log
|
|
fi
|
|
done
|
|
|
|
#Dumping the database
|
|
#DATE=$(date +"%Y_%m_%d_%H_%M_%S")
|
|
DATE=$(date +'%Y-%m-%dT%H:%M:%SZ')
|
|
$MYSQLDUMP $MYSQL_BACKUP_MYSQLDUMP_OPTIONS "${DBNAME[@]}" \
|
|
> $BACKUPS_DIR/mariadb.all.sql 2>dberror.log
|
|
if [[ $? -eq 0 && -s $BACKUPS_DIR/mariadb.all.sql ]]
|
|
then
|
|
#Archive the current db files
|
|
pushd $BACKUPS_DIR 1>/dev/null
|
|
tar zcvf $ARCHIVE_DIR/mariadb.all.${DATE}.tar.gz *
|
|
ARCHIVE_RET=$?
|
|
popd 1>/dev/null
|
|
else
|
|
#TODO: This can be convert into mail alert of alert send to a monitoring system
|
|
echo "Backup failed and need attention."
|
|
cat dberror.log
|
|
exit 1
|
|
fi
|
|
|
|
#Remove the current backup
|
|
if [ -d $BACKUPS_DIR ]
|
|
then
|
|
rm -rf $BACKUPS_DIR/*.sql
|
|
fi
|
|
|
|
#Only delete the old archive after a successful archive
|
|
if [ $ARCHIVE_RET -eq 0 ]
|
|
then
|
|
if [ "$MARIADB_BACKUP_DAYS_TO_KEEP" -gt 0 ]
|
|
then
|
|
echo "Deleting backups older than $MARIADB_BACKUP_DAYS_TO_KEEP days"
|
|
if [ -d $ARCHIVE_DIR ]
|
|
then
|
|
for archive_file in $(ls -1 $ARCHIVE_DIR/*.gz)
|
|
do
|
|
archive_date=$( echo $archive_file | awk -F/ '{print $NF}' | cut -d'.' -f 3)
|
|
if [ "$(seconds_difference $archive_date)" -gt "$(($MARIADB_BACKUP_DAYS_TO_KEEP*86400))" ]
|
|
then
|
|
rm -rf $archive_file
|
|
fi
|
|
done
|
|
fi
|
|
fi
|
|
fi
|