A script to automatically back up all databases running under docker on a host
- MariaDB
- MySQL
- PostgreSQL
This container requires access to the docker socket. This can be done either by mounting /var/lib/docker.sock
, or using a HTTP proxy to provide it through $DOCKER_HOST
.
Mount your backup directory as /var/backups
(or override $BACKUP_DIR
). Backups will be saved here based on the name of the container. Backups are not dated or compressed.
Backups run daily, usually at midnight. To change this, add a cron-style schedule to $SCHEDULE
. The container uses supercronic
as the schedule manager. For more information on the format of the cron strings, please see the cronexpr
documentation.
Additionally, there is support for healthchecks.io. $HEALTHCHECKS_ID
can be used to specify the id to ping. If you're using a self-hosted instance, set $HEALTHCHECKS_HOST
.
version: "2.3"
services:
backup:
image: ghcr.io/realorangeone/db-auto-backup:latest
restart: unless-stopped
volumes:
- /var/run/docker.sock:/var/run/docker.sock:ro
- ./backups:/var/backups
environment:
- HEALTHCHECKS_ID=id