2011-09-17 16:15:31 +02:00
#!/bin/sh
# Updates etc at: https://github.com/woxxy/MySQL-backup-to-Amazon-S3
# Under a MIT license
2011-09-17 18:54:16 +02:00
# change these variables to what you need
2011-09-17 18:52:16 +02:00
MYSQLROOT = root
MYSQLPASS = password
2011-09-17 20:40:22 +02:00
S3BUCKET = my-db-backup-bucket
# when running via cron, the PATHs MIGHT be different. If you have a custom/manual MYSQL install, you should set this manually like MYSQLDUMPPATH=/usr/local/mysql/bin/
MYSQLDUMPPATH =
2011-09-17 18:52:16 +02:00
2011-09-17 16:15:31 +02:00
# dump all databases
2011-09-17 20:40:22 +02:00
${ MYSQLDUMPPATH } mysqldump --quick --user= ${ MYSQLROOT } --password= ${ MYSQLPASS } --single-transaction --all-databases > ~/all-databases.sql
2011-09-17 16:15:31 +02:00
if [ $1 != month ]
then
if [ $1 != week ]
then
PERIOD = day
else
PERIOD = week
fi
else
PERIOD = month
fi
# we want at least two backups, two months, two weeks, and two days
2011-09-17 18:53:21 +02:00
s3cmd del --recursive s3://${ S3BUCKET } /previous_${ PERIOD } /
2011-09-17 18:52:16 +02:00
s3cmd mv --recursive s3://${ S3BUCKET } /${ PERIOD } / s3://${ S3BUCKET } /previous_${ PERIOD } /
2011-09-17 16:15:31 +02:00
# upload all databases
2011-09-17 18:52:16 +02:00
s3cmd put -f ~/all-databases.sql s3://${ S3BUCKET } /${ PERIOD } /
2011-09-17 16:15:31 +02:00
# remove databases dump
rm ~/all-databases.sql