From 4401095e01f3e182d683c250db23d1ab4d54379a Mon Sep 17 00:00:00 2001 From: Jannis Fedoruk-Betschki Date: Sun, 4 Aug 2024 15:50:28 +0200 Subject: [PATCH] Update README.md --- README.md | 21 +++++++++++++-------- 1 file changed, 13 insertions(+), 8 deletions(-) diff --git a/README.md b/README.md index c2ba9a4..dd45635 100644 --- a/README.md +++ b/README.md @@ -2,7 +2,7 @@ ## Overview -This repository is an open-source tool designed to create and manage MySQL database backups. It allows you to store backups both onsite (e.g., on your own server or NAS) and offsite (e.g., on an S3-compatible storage). This ensures data redundancy and security, protecting against data loss in various scenarios. +This repository is an open-source tool designed to create and manage MySQL database backups. It allows you to store backups both onsite (e.g., on your own server or NAS) and offsite (e.g., on S3-compatible storage). This ensures data redundancy and security, protecting against data loss in various scenarios. This tool was developed for the specific use case at [Magic Pages](https://magicpages.com), a managed Ghost CMS hosting provider, to maintain robust backups of all databases. However, it can be used by anyone needing a reliable MySQL backup solution. @@ -23,14 +23,14 @@ This tool was developed for the specific use case at [Magic Pages](https://magic ## Installation -1. **Clone the Repository:** +1. **Clone the Repository** ```sh git clone https://github.com/magicpages/mysql-onsite-offsite-backup.git cd mysql-onsite-offsite-backup ``` -2. Create and Configure the .env File: +2. **Create and Configure the .env File** Create a .env file in the root directory and fill in the necessary environment variables: @@ -52,16 +52,16 @@ MONTHLY_RETENTION=6 YEARLY_RETENTION=2 ``` -3. Build and Run the Docker Container: +3. **Build and Run the Docker Container** ```sh -docker-compose build -docker-compose up -d +docker compose up -d ``` ## Usage ### Backup + The backup process is automated using a cron job configured in the Docker container. The backup script will: 1. Connect to the MySQL server. @@ -71,16 +71,18 @@ The backup process is automated using a cron job configured in the Docker contai 5. Store the compressed dumps both locally (on your server or NAS) and offsite (on S3-compatible storage). ### Cleanup + The cleanup process is also automated using a cron job. It will: 1. Remove old backups based on the retention policy both onsite and offsite. ### Manual Trigger + You can manually trigger the backup and cleanup scripts inside the running container: ```sh # Enter the running container -docker exec -it mysql-onsite-offsite-backup-backup-1 bash # Replace with your container name +docker exec -it mysql-onsite-offsite-backup_backup_1 bash # Run backup script bash /usr/local/bin/backup.bash @@ -90,6 +92,7 @@ bash /usr/local/bin/cleanup.bash ``` ## Configuration + The tool is configured via environment variables in the .env file. The following variables are required: - MYSQL_USER: MySQL username @@ -100,10 +103,12 @@ The tool is configured via environment variables in the .env file. The following - S3_BUCKET_NAME: S3 bucket name - S3_HOST_BASE: S3 host base URL - S3_HOST_BUCKET: S3 host bucket URL pattern -- S3_BUCKET_LOCATION: S3 bucket location. +- S3_BUCKET_LOCATION: S3 bucket location +- DAILY_RETENTION: Number of daily backups to retain - WEEKLY_RETENTION: Number of weekly backups to retain - MONTHLY_RETENTION: Number of monthly backups to retain - YEARLY_RETENTION: Number of yearly backups to retain ### Cron Schedule + The default cron schedule is set to run the backup and cleanup scripts at 2 AM daily (the server's local time). You can customize this by editing the crontab file in the project directory. \ No newline at end of file