Skip to content

Instantly share code, notes, and snippets.

@henriquemoody
Created February 24, 2015 17:57
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 1 You must be signed in to fork a gist
  • Save henriquemoody/38b05cfdfbfb2dadcd44 to your computer and use it in GitHub Desktop.
Save henriquemoody/38b05cfdfbfb2dadcd44 to your computer and use it in GitHub Desktop.
#!/usr/bin/env bash
set -e
DATE_FORMAT="%Y-%m-%d"
DATE_CREATION=$(date "+${DATE_FORMAT}")
DATE_REMOVAL=$(date -d "20 day ago" "+${DATE_FORMAT}")
DIRECTORY_BASE="/backup/mysql"
DIRECTORY_CREATION="${DIRECTORY_BASE}/${DATE_CREATION}"
DIRECTORY_REMOVAL="${DIRECTORY_BASE}/${DATE_REMOVAL}"
MYSQL_USER="root"
MYSQL_PASSWORD="root"
MYSQL_HOST="127.0.0.1"
echo "Creating '${DIRECTORY_CREATION}' backup directory"
mkdir -p "${DIRECTORY_CREATION}"
echo
mysql -u $MYSQL_USER -h $MYSQL_HOST -p$MYSQL_PASSWORD -Bse 'SHOW DATABASES' |
egrep -v '^(information_schema|mysql|performance_schema)$' |
while read database; do
echo "- Dumping '${database}' database"
filename="${DIRECTORY_CREATION}/${database}.${DATE_CREATION}.gz"
mysqldump --single-transaction -u $MYSQL_USER -h ${MYSQL_HOST} -p${MYSQL_PASSWORD} ${database} |
gzip -9 > "${filename}"
done
echo
if [ -d "${DIRECTORY_REMOVAL}" ]; then
echo "Removing backup from ${DATE_REMOVAL}"
rm -rf "${DIRECTORY_REMOVAL}"
echo
fi
echo "Finished!"
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment