asmbs / mysql-s3-backup
Manages backups of a MySQL database to Amazon S3
Installs: 5
Dependents: 0
Suggesters: 0
Security: 0
Stars: 1
Watchers: 4
Forks: 0
Open Issues: 0
Type:project
Requires
- php: >=7.2
- aws/aws-sdk-php: ^3.61
- ifsnop/mysqldump-php: ^2.7
- symfony/console: ^4.3
- symfony/yaml: ^4.1
This package is auto-updated.
Last update: 2025-01-21 20:07:42 UTC
README
Manages backups of a MySQL database to Amazon S3
Requirements
- PHP 7.2+
- MySQL 4.1.0+
- Composer 1.6.5+
Installation
-
Create an empty, non-versioned S3 bucket. The first time that the script runs, it will create 4 folders for you ("yearly", "monthly", "daily", and "hourly").
-
Copy
config.yaml.dist
to a new file namedconfig.yaml
in the same directory and configure it to your needs, per the Configuration Reference below. -
Install the dependencies:
composer install
-
Set up a single
cron
job to executeMySQLS3Backup.php
once every hour. Usingcrontab
, an example line would be:0 * * * * php /path/to/mysql-s3-backup/src/MySQLS3Backup.php app:manage
The backup files will be created in the format YYYY-MM-DD_HH-MM-SS.EXT
, where EXT
is the file extension based on the compression method chosen (sql
for "None", gz
for "Gzip", and bz2
for "Bzip2"). The file names should not be changed inside the bucket, or else the script will not be able to recognize the files.
Usage
You can manually execute the "manage" command by running:
php src/MySQLS3Backup.php app:manage
To download a previous dump that was uploaded using client-side encryption, it must be downloaded with the "download-encrypted" command. You can do this by running:
php src/MySQLS3Backup.php app:download-encrypted "hourly/2019-06-19_16-07-24.sql.gz" --output-file="/var/tmp/bar.sql.gz"
Configuration Reference
s3
arguments
version
The S3 version to useregion
The S3 region to usecredentials
key
Your S3 keysecret
Your S3 secret
client_encryption
enabled
If set to true, then dump files will be transferred to S3 using client-side encryption with an AWS KMS-managed customer master key. If set to false, then plain non-encrypted transfer will be used.arguments
version
region
credentials
key
secret
key_arn
The ARN of the KMS-managed customer key to use. Typically, this will begin with "arn:aws:kms".cipher_options
- Should be "cbc" or "gcm". See AWS PHP SDK documentation.
- Should be "128", "192", or "256". See AWS PHP SDK documentation.
sns
enabled
If set to true, then exceptions will be sent to an Amazon SNS Topic. If set to false, exceptions will simply be outputted.arguments
version
region
credentials
key
secret
topic_arn
The ARN of the Amazon SNS Topic to use. Typically, this will begin with "arn:aws:sns".
mysql
host
The host on which your database is hosteddbname
The name of your databaseusername
The username to be used by MySQLpassword
The password to be used by MySQL
app
output
If set to true, then information will be outputted. If set to false, the script will run silently (except for exceptions).compression
The compression algorithm to use. This should be 'None', 'Gzip', or 'Bzip2'. Note that bzip2 support is not enabled by default in PHP.maximum_backup_counts
This is the maximum number of backups to keep based on each time period. For example, setting 'yearly' to '7' will keep one backup for each of the past 7 years. When a day rolls over, the most recent 'hourly' backup will be used.yearly
monthly
daily
hourly
mirror_default_opt
If set to true, then the dump settings will mirror the default--opt
setting of MySQL's originalmysqldump
.add_sql_extension
If set to true, then.sql
will be added before the compression extension (e.g..gz
) in compressed backups.