mirror of
https://github.com/jkaninda/mysql-bkup.git
synced 2025-12-07 05:59:43 +01:00
Merge pull request #26 from jkaninda/develop
Add database connection testing before running in scheduled mode
This commit is contained in:
@@ -44,6 +44,20 @@ error()
|
|||||||
echo "$arg0: $*" >&2
|
echo "$arg0: $*" >&2
|
||||||
exit 0
|
exit 0
|
||||||
}
|
}
|
||||||
|
info() {
|
||||||
|
{ set +x; } 2> /dev/null
|
||||||
|
echo 'mysql-bkup:' '[INFO] ' "$@"
|
||||||
|
#set -x
|
||||||
|
}
|
||||||
|
warning() {
|
||||||
|
{ set +x; } 2> /dev/null
|
||||||
|
echo 'mysql-bkup:' '[WARNING] ' "$@"
|
||||||
|
}
|
||||||
|
fatal() {
|
||||||
|
{ set +x; } 2> /dev/null
|
||||||
|
echo 'mysql-bkup:' '[ERROR] ' "$@" >&2
|
||||||
|
exit 1
|
||||||
|
}
|
||||||
|
|
||||||
help()
|
help()
|
||||||
{
|
{
|
||||||
@@ -131,15 +145,16 @@ flags()
|
|||||||
backup()
|
backup()
|
||||||
{
|
{
|
||||||
if [[ -z $DB_HOST ]] || [[ -z $DB_NAME ]] || [[ -z $DB_USERNAME ]] || [[ -z $DB_PASSWORD ]]; then
|
if [[ -z $DB_HOST ]] || [[ -z $DB_NAME ]] || [[ -z $DB_USERNAME ]] || [[ -z $DB_PASSWORD ]]; then
|
||||||
echo "Please make sure all required environment variables are set "
|
fatal "Please make sure all required environment variables are set "
|
||||||
else
|
else
|
||||||
## Test database connection
|
## Test database connection
|
||||||
mysql -h ${DB_HOST} -P ${DB_PORT} -u ${DB_USERNAME} --password=${DB_PASSWORD} ${DB_NAME} -e"quit"
|
test_database_connection
|
||||||
|
##mysql -h ${DB_HOST} -P ${DB_PORT} -u ${DB_USERNAME} --password=${DB_PASSWORD} ${DB_NAME} -e"quit"
|
||||||
|
|
||||||
## Backup database
|
## Backup database
|
||||||
mysqldump -h ${DB_HOST} -P ${DB_PORT} -u ${DB_USERNAME} --password=${DB_PASSWORD} ${DB_NAME} | gzip > ${STORAGE_PATH}/${DB_NAME}_${TIME}.sql.gz
|
mysqldump -h ${DB_HOST} -P ${DB_PORT} -u ${DB_USERNAME} --password=${DB_PASSWORD} ${DB_NAME} | gzip > ${STORAGE_PATH}/${DB_NAME}_${TIME}.sql.gz
|
||||||
echo "$TIME: ${DB_NAME}_${TIME}.sql.gz" | tee -a "${STORAGE_PATH}/history.txt"
|
info "$TIME: ${DB_NAME}_${TIME}.sql.gz" | tee -a "${STORAGE_PATH}/history.txt"
|
||||||
echo "Database has been saved"
|
info "Database has been saved"
|
||||||
fi
|
fi
|
||||||
exit 0
|
exit 0
|
||||||
}
|
}
|
||||||
@@ -147,7 +162,7 @@ exit 0
|
|||||||
restore()
|
restore()
|
||||||
{
|
{
|
||||||
if [[ -z $DB_HOST ]] || [[ -z $DB_NAME ]] || [[ -z $DB_USERNAME ]] || [[ -z $DB_PASSWORD ]]; then
|
if [[ -z $DB_HOST ]] || [[ -z $DB_NAME ]] || [[ -z $DB_USERNAME ]] || [[ -z $DB_PASSWORD ]]; then
|
||||||
echo "Please make sure all required environment variables are set "
|
fatal "Please make sure all required environment variables are set "
|
||||||
else
|
else
|
||||||
## Restore database
|
## Restore database
|
||||||
if [ -f "${STORAGE_PATH}/$FILE_NAME" ]; then
|
if [ -f "${STORAGE_PATH}/$FILE_NAME" ]; then
|
||||||
@@ -156,9 +171,9 @@ else
|
|||||||
else
|
else
|
||||||
cat ${STORAGE_PATH}/${FILE_NAME} | mysql -h ${DB_HOST} -P ${DB_PORT} -u ${DB_USERNAME} --password=${DB_PASSWORD} ${DB_NAME}
|
cat ${STORAGE_PATH}/${FILE_NAME} | mysql -h ${DB_HOST} -P ${DB_PORT} -u ${DB_USERNAME} --password=${DB_PASSWORD} ${DB_NAME}
|
||||||
fi
|
fi
|
||||||
echo "Database has been restored"
|
info "Database has been restored"
|
||||||
else
|
else
|
||||||
echo "Error, file not found in ${STORAGE_PATH}/${FILE_NAME}"
|
fatal "file not found in ${STORAGE_PATH}/${FILE_NAME}"
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
exit
|
exit
|
||||||
@@ -180,23 +195,33 @@ s3_restore()
|
|||||||
mount_s3()
|
mount_s3()
|
||||||
{
|
{
|
||||||
if [[ -z $ACCESS_KEY ]] || [[ -z $SECRET_KEY ]]; then
|
if [[ -z $ACCESS_KEY ]] || [[ -z $SECRET_KEY ]]; then
|
||||||
echo "Please make sure all environment variables are set "
|
info "Please make sure all environment variables are set "
|
||||||
echo "BUCKETNAME=$BUCKETNAME \nACCESS_KEY=$nACCESS_KEY \nSECRET_KEY=$SECRET_KEY"
|
|
||||||
else
|
else
|
||||||
echo "$ACCESS_KEY:$SECRET_KEY" | tee /etc/passwd-s3fs
|
echo "$ACCESS_KEY:$SECRET_KEY" | tee /etc/passwd-s3fs
|
||||||
chmod 600 /etc/passwd-s3fs
|
chmod 600 /etc/passwd-s3fs
|
||||||
echo "Mounting Object storage in /s3mnt .... "
|
info "Mounting Object storage in /s3mnt .... "
|
||||||
if [ -z "$(ls -A /s3mnt)" ]; then
|
if [ -z "$(ls -A /s3mnt)" ]; then
|
||||||
s3fs $BUCKETNAME /s3mnt -o passwd_file=/etc/passwd-s3fs -o use_cache=/tmp/s3cache -o allow_other -o url=$S3_ENDPOINT -o use_path_request_style
|
s3fs $BUCKETNAME /s3mnt -o passwd_file=/etc/passwd-s3fs -o use_cache=/tmp/s3cache -o allow_other -o url=$S3_ENDPOINT -o use_path_request_style
|
||||||
if [ ! -d "/s3mnt$S3_PATH" ]; then
|
if [ ! -d "/s3mnt$S3_PATH" ]; then
|
||||||
mkdir -p /s3mnt$S3_PATH
|
mkdir -p /s3mnt$S3_PATH
|
||||||
fi
|
fi
|
||||||
else
|
else
|
||||||
echo "Object storage already mounted in /s3mnt"
|
info "Object storage already mounted in /s3mnt"
|
||||||
fi
|
fi
|
||||||
export STORAGE_PATH=/s3mnt$S3_PATH
|
export STORAGE_PATH=/s3mnt$S3_PATH
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
umount_s3()
|
||||||
|
{
|
||||||
|
info "Umount /s3mnt..."
|
||||||
|
umount /s3mnt
|
||||||
|
}
|
||||||
|
test_database_connection()
|
||||||
|
{
|
||||||
|
info "Testing database connection..."
|
||||||
|
## Test database connection
|
||||||
|
mysql -h ${DB_HOST} -P ${DB_PORT} -u ${DB_USERNAME} --password=${DB_PASSWORD} ${DB_NAME} -e"quit"
|
||||||
|
}
|
||||||
create_crontab_script()
|
create_crontab_script()
|
||||||
{
|
{
|
||||||
TASK=/usr/local/bin/backup_cron.sh
|
TASK=/usr/local/bin/backup_cron.sh
|
||||||
@@ -236,13 +261,13 @@ scheduled_mode()
|
|||||||
echo "**********************************"
|
echo "**********************************"
|
||||||
echo " Starting MySQL Bkup... "
|
echo " Starting MySQL Bkup... "
|
||||||
echo "***********************************"
|
echo "***********************************"
|
||||||
echo "Running in Scheduled mode"
|
info "Running in Scheduled mode"
|
||||||
echo "Log file in /var/log/mysql-bkup.log"
|
info "Log file in /var/log/mysql-bkup.log"
|
||||||
echo "Execution period $SCHEDULE_PERIOD"
|
info "Execution period $SCHEDULE_PERIOD"
|
||||||
|
test_database_connection
|
||||||
supervisord -c /etc/supervisor/supervisord.conf
|
supervisord -c /etc/supervisor/supervisord.conf
|
||||||
else
|
else
|
||||||
echo "Scheduled mode supports only backup operation"
|
fatal "Scheduled mode supports only backup operation"
|
||||||
exit 1
|
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -254,19 +279,19 @@ then
|
|||||||
then
|
then
|
||||||
if [ $STORAGE != 's3' ]
|
if [ $STORAGE != 's3' ]
|
||||||
then
|
then
|
||||||
echo "Restore from local"
|
info "Restore from local"
|
||||||
restore
|
restore
|
||||||
else
|
else
|
||||||
echo "Restore from s3"
|
info "Restore from s3"
|
||||||
s3_restore
|
s3_restore
|
||||||
fi
|
fi
|
||||||
else
|
else
|
||||||
if [ $STORAGE != 's3' ]
|
if [ $STORAGE != 's3' ]
|
||||||
then
|
then
|
||||||
echo "Backup to local destination"
|
info "Backup to local storage"
|
||||||
backup
|
backup
|
||||||
else
|
else
|
||||||
echo "Backup to s3 storage"
|
info "Backup to s3 storage"
|
||||||
s3_backup
|
s3_backup
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
@@ -274,6 +299,5 @@ elif [ $EXECUTION_MODE == 'scheduled' ]
|
|||||||
then
|
then
|
||||||
scheduled_mode
|
scheduled_mode
|
||||||
else
|
else
|
||||||
echo "Error, unknow execution mode!"
|
fatal "Error, unknow execution mode!"
|
||||||
exit 1
|
|
||||||
fi
|
fi
|
||||||
Reference in New Issue
Block a user