Files
MySQL-backup-to-Amazon-S3/mysqltos3.sh

34 lines
776 B
Bash
Raw Normal View History

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:52:16 +02:00
MYSQLROOT=root
MYSQLPASS=password
S3BUCKET=mybucket
2011-09-17 16:15:31 +02:00
# dump all databases
2011-09-17 18:52:16 +02:00
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:52:16 +02:00
s3cmd del --recursive s3://${S3BUCKET}/my-database-backups/previous_${PERIOD}/
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