mirror of
https://github.com/fradelg/docker-mysql-cron-backup.git
synced 2025-01-18 16:22:33 +01:00
Merge pull request #93 from g-nardiello/feature-exit-backup
[Feature] Make backup on container shutdown
This commit is contained in:
commit
90ad75a24e
2 changed files with 83 additions and 2 deletions
64
README.md
64
README.md
|
@ -31,6 +31,7 @@ docker container run -d \
|
||||||
- `MAX_BACKUPS`: The number of backups to keep. When reaching the limit, the old backup will be discarded. No limit by default.
|
- `MAX_BACKUPS`: The number of backups to keep. When reaching the limit, the old backup will be discarded. No limit by default.
|
||||||
- `INIT_BACKUP`: If set, create a backup when the container starts.
|
- `INIT_BACKUP`: If set, create a backup when the container starts.
|
||||||
- `INIT_RESTORE_LATEST`: If set, restores latest backup.
|
- `INIT_RESTORE_LATEST`: If set, restores latest backup.
|
||||||
|
- `EXIT_BACKUP`: If set, create a backup when the container stops.
|
||||||
- `TIMEOUT`: Wait a given number of seconds for the database to be ready and make the first backup, `10s` by default. After that time, the initial attempt for backup gives up and only the Cron job will try to make a backup.
|
- `TIMEOUT`: Wait a given number of seconds for the database to be ready and make the first backup, `10s` by default. After that time, the initial attempt for backup gives up and only the Cron job will try to make a backup.
|
||||||
- `GZIP_LEVEL`: Specify the level of gzip compression from 1 (quickest, least compressed) to 9 (slowest, most compressed), default is 6.
|
- `GZIP_LEVEL`: Specify the level of gzip compression from 1 (quickest, least compressed) to 9 (slowest, most compressed), default is 6.
|
||||||
- `USE_PLAIN_SQL`: If set, back up and restore plain SQL files without gzip.
|
- `USE_PLAIN_SQL`: If set, back up and restore plain SQL files without gzip.
|
||||||
|
@ -184,4 +185,65 @@ mysql-cron-backup:
|
||||||
docker container exec <your_mysql_backup_container_name> /restore.sh /backup/<your_sql_backup_gz_file>
|
docker container exec <your_mysql_backup_container_name> /restore.sh /backup/<your_sql_backup_gz_file>
|
||||||
```
|
```
|
||||||
|
|
||||||
if no database name is specified, `restore.sh` will try to find the database name from the backup file.
|
if no database name is specified, `restore.sh` will try to find the database name from the backup file.
|
||||||
|
|
||||||
|
### Automatic backup and restore on container starts and stops
|
||||||
|
|
||||||
|
Set `INIT_RESTORE_LATEST` to automatic restore the last backup on startup.
|
||||||
|
Set `EXIT_BACKUP` to automatic create a last backup on shutdown.
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
mysql-cron-backup:
|
||||||
|
image: fradelg/mysql-cron-backup
|
||||||
|
depends_on:
|
||||||
|
- mariadb
|
||||||
|
volumes:
|
||||||
|
- ${VOLUME_PATH}/backup:/backup
|
||||||
|
environment:
|
||||||
|
- MYSQL_HOST=my_mariadb
|
||||||
|
- MYSQL_USER=${MYSQL_USER}
|
||||||
|
- MYSQL_PASS=${MYSQL_PASSWORD}
|
||||||
|
- MAX_BACKUPS=15
|
||||||
|
- INIT_RESTORE_LATEST=1
|
||||||
|
- EXIT_BACKUP=1
|
||||||
|
# Every day at 03:00
|
||||||
|
- CRON_TIME=0 3 * * *
|
||||||
|
# Make it small
|
||||||
|
- GZIP_LEVEL=9
|
||||||
|
restart: unless-stopped
|
||||||
|
|
||||||
|
volumes:
|
||||||
|
data:
|
||||||
|
```
|
||||||
|
|
||||||
|
Docker database image could expose a directory you could add files as init sql script.
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
mysql:
|
||||||
|
image: mysql
|
||||||
|
expose:
|
||||||
|
- 3306
|
||||||
|
volumes:
|
||||||
|
- data:/var/lib/mysql
|
||||||
|
# If there is not scheme, restore using the init script (if exists)
|
||||||
|
- ./init-script.sql:/docker-entrypoint-initdb.d/database.sql.gz
|
||||||
|
environment:
|
||||||
|
- MYSQL_ROOT_PASSWORD=${MYSQL_ROOT_PASSWORD}
|
||||||
|
- MYSQL_DATABASE=${DATABASE_NAME}
|
||||||
|
restart: unless-stopped
|
||||||
|
```
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
mariadb:
|
||||||
|
image: mariadb
|
||||||
|
expose:
|
||||||
|
- 3306
|
||||||
|
volumes:
|
||||||
|
- data:/var/lib/mysql
|
||||||
|
# If there is not scheme, restore using the init script (if exists)
|
||||||
|
- ./init-script.sql:/docker-entrypoint-initdb.d/database.sql.gz
|
||||||
|
environment:
|
||||||
|
- MYSQL_ROOT_PASSWORD=${MARIADB_ROOT_PASSWORD}
|
||||||
|
- MYSQL_DATABASE=${DATABASE_NAME}
|
||||||
|
restart: unless-stopped
|
||||||
|
```
|
21
run.sh
21
run.sh
|
@ -16,7 +16,26 @@ elif [ -n "${INIT_RESTORE_LATEST}" ]; then
|
||||||
find /backup -maxdepth 1 -name '[0-9]*.*.sql.gz' | sort | tail -1 | xargs /restore.sh
|
find /backup -maxdepth 1 -name '[0-9]*.*.sql.gz' | sort | tail -1 | xargs /restore.sh
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
function final_backup {
|
||||||
|
echo "=> Captured trap for final backup"
|
||||||
|
DATE=$(date +%Y%m%d%H%M)
|
||||||
|
echo "=> Requested last backup at $(date "+%Y-%m-%d %H:%M:%S")"
|
||||||
|
exec /backup.sh
|
||||||
|
exit 0
|
||||||
|
}
|
||||||
|
|
||||||
|
if [ -n "${EXIT_BACKUP}" ]; then
|
||||||
|
echo "=> Listening on container shutdown gracefully to make last backup before close"
|
||||||
|
trap final_backup SIGHUP SIGINT SIGTERM
|
||||||
|
fi
|
||||||
|
|
||||||
echo "${CRON_TIME} /backup.sh >> /mysql_backup.log 2>&1" > /tmp/crontab.conf
|
echo "${CRON_TIME} /backup.sh >> /mysql_backup.log 2>&1" > /tmp/crontab.conf
|
||||||
crontab /tmp/crontab.conf
|
crontab /tmp/crontab.conf
|
||||||
echo "=> Running cron task manager in foreground"
|
echo "=> Running cron task manager in foreground"
|
||||||
exec crond -f -l 8 -L /mysql_backup.log
|
crond -f -l 8 -L /mysql_backup.log &
|
||||||
|
|
||||||
|
echo "Listening on crond, and wait..."
|
||||||
|
|
||||||
|
tail -f /dev/null & wait $!
|
||||||
|
|
||||||
|
echo "Script is shutted down."
|
Loading…
Reference in a new issue