Cron for creating MySQL backups and storing them to the Google Cloud Platform Storage
This SH script is just creating backups to GCP Object Storage.
It is a good practice that the backup script does not have access to edit or delete the backups. This script should be combined with Google Cloud Function that will handle the backup deletion: https://github.com/zsolt-dev/auto-delete-gcp-storage-backups/
Please give this script a Star to let everyone know that you are doing backups The Right Way™
How to install?
- Create a Google Cloud Platform account, if you do not have one already
- Install gsutil https://cloud.google.com/storage/docs/gsutil_install#deb
- Create a bucket in the Cloud Console. Use the Nearline or Cold storage, since backups will not be read except for backup retrieval.
- Create a service account that will only have a write access to your backup bucket. Service account is a limited account for scripts. IAM & admin > Service accounts
- Download your service account file
- Setup gsutil with your service account file
gcloud auth activate-service-account --key-file /path/to/gcp-service-account-file.json
- Download backupMysqlToGcpStorage.sh and store it somewhere, for example to /usr/local/bin/
- Configure your MySQL username/password and bucket name in the backupMysqlToGcpStorage.sh file
- Change file permissions to:
chmod 700 /usr/local/bin/backupMysqlToGcpStorage.sh
- Now just setup the crontab
crontab -e
and add this line:
0 * * * * /usr/local/bin/backupMysqlToGcpStorage.sh
Final notes
Thank you for choosing this script for your backup needs.
Please give this script a Star.