2022-01-06 16:09:33 +01:00
< a href = "https://www.offen.dev/" >
2022-01-06 16:07:00 +01:00
< img src = "https://offen.github.io/press-kit/offen-material/gfx-GitHub-Offen-logo.svg" alt = "Offen logo" title = "Offen" width = "150px" / >
< / a >
2021-04-02 13:45:33 +02:00
# docker-volume-backup
2021-04-02 13:59:47 +02:00
2021-08-19 09:25:53 +02:00
Backup Docker volumes locally or to any S3 compatible storage.
2021-04-02 13:59:47 +02:00
2021-08-29 10:23:25 +02:00
The [offen/docker-volume-backup ](https://hub.docker.com/r/offen/docker-volume-backup ) Docker image can be used as a lightweight (below 15MB) sidecar container to an existing Docker setup.
2022-01-22 13:35:13 +01:00
It handles __recurring or one-off backups of Docker volumes__ to a __local directory__ , __any S3 or WebDAV compatible storage (or any combination) and rotates away old backups__ if configured. It also supports __encrypting your backups using GPG__ and __sending notifications for failed backup runs__ .
2021-08-29 10:23:25 +02:00
<!-- MarkdownTOC -->
- [Quickstart ](#quickstart )
2021-09-11 10:30:36 +02:00
- [Recurring backups in a compose setup ](#recurring-backups-in-a-compose-setup )
- [One-off backups using Docker CLI ](#one-off-backups-using-docker-cli )
2021-08-29 10:23:25 +02:00
- [Configuration reference ](#configuration-reference )
- [How to ](#how-to )
- [Stopping containers during backup ](#stopping-containers-during-backup )
- [Automatically pruning old backups ](#automatically-pruning-old-backups )
2021-09-09 08:58:03 +02:00
- [Send email notifications on failed backup runs ](#send-email-notifications-on-failed-backup-runs )
2022-02-11 20:06:23 +01:00
- [Customize notifications ](#customize-notifications )
2021-08-29 10:23:25 +02:00
- [Encrypting your backup using GPG ](#encrypting-your-backup-using-gpg )
- [Restoring a volume from a backup ](#restoring-a-volume-from-a-backup )
2021-10-23 17:45:57 +02:00
- [Set the timezone the container runs in ](#set-the-timezone-the-container-runs-in )
2021-08-29 10:23:25 +02:00
- [Using with Docker Swarm ](#using-with-docker-swarm )
- [Manually triggering a backup ](#manually-triggering-a-backup )
2021-12-17 08:31:28 +01:00
- [Update deprecated email configuration ](#update-deprecated-email-configuration )
2021-08-29 10:23:25 +02:00
- [Recipes ](#recipes )
- [Backing up to AWS S3 ](#backing-up-to-aws-s3 )
2022-02-02 17:22:42 +01:00
- [Backing up to Filebase ](#backing-up-to-filebase )
2021-08-29 10:23:25 +02:00
- [Backing up to MinIO ](#backing-up-to-minio )
2022-01-22 13:29:21 +01:00
- [Backing up to WebDAV ](#backing-up-to-webdav )
2021-08-29 10:23:25 +02:00
- [Backing up locally ](#backing-up-locally )
- [Backing up to AWS S3 as well as locally ](#backing-up-to-aws-s3-as-well-as-locally )
- [Running on a custom cron schedule ](#running-on-a-custom-cron-schedule )
- [Rotating away backups that are older than 7 days ](#rotating-away-backups-that-are-older-than-7-days )
- [Encrypting your backups using GPG ](#encrypting-your-backups-using-gpg )
- [Running multiple instances in the same setup ](#running-multiple-instances-in-the-same-setup )
- [Differences to `futurice/docker-volume-backup` ](#differences-to-futuricedocker-volume-backup )
<!-- /MarkdownTOC -->
2021-04-02 14:17:09 +02:00
2021-08-29 10:23:25 +02:00
---
Code and documentation for `v1` versions are found on [this branch][v1-branch].
[v1-branch]: https://github.com/offen/docker-volume-backup/tree/v1
## Quickstart
2021-09-11 10:30:36 +02:00
### Recurring backups in a compose setup
2021-08-29 10:23:25 +02:00
Add a `backup` service to your compose setup and mount the volumes you would like to see backed up:
```yml
version: '3'
services:
volume-consumer:
build:
context: ./my-app
volumes:
- data:/var/my-app
labels:
# This means the container will be stopped during backup to ensure
# backup integrity. You can omit this label if stopping during backup
# not required.
- docker-volume-backup.stop-during-backup=true
backup:
2021-09-09 08:58:03 +02:00
# In production, it is advised to lock your image tag to a proper
# release version instead of using `latest` .
# Check https://github.com/offen/docker-volume-backup/releases
# for a list of available releases.
2021-08-29 10:23:25 +02:00
image: offen/docker-volume-backup:latest
restart: always
env_file: ./backup.env # see below for configuration reference
volumes:
- data:/backup/my-app-backup:ro
# Mounting the Docker socket allows the script to stop and restart
# the container during backup. You can omit this if you don't want
# to stop the container
- /var/run/docker.sock:/var/run/docker.sock:ro
# If you mount a local directory or volume to `/archive` a local
# copy of the backup will be stored there. You can override the
# location inside of the container by setting `BACKUP_ARCHIVE` .
# You can omit this if you do not want to keep local backups.
- /path/to/local_backups:/archive
volumes:
data:
```
2021-09-11 10:30:36 +02:00
### One-off backups using Docker CLI
To run a one time backup, mount the volume you would like to see backed up into a container and run the `backup` command:
```console
docker run --rm \
-v data:/backup/data \
--env AWS_ACCESS_KEY_ID="< xxx > " \
--env AWS_SECRET_ACCESS_KEY="< xxx > " \
--env AWS_S3_BUCKET_NAME="< xxx > " \
--entrypoint backup \
offen/docker-volume-backup:latest
```
Alternatively, pass a `--env-file` in order to use a full config as described below.
2021-08-29 10:23:25 +02:00
## Configuration reference
2021-04-02 14:17:09 +02:00
2021-08-29 10:23:25 +02:00
Backup targets, schedule and retention are configured in environment variables.
You can populate below template according to your requirements and use it as your `env_file` :
2021-04-02 14:17:09 +02:00
```ini
########### BACKUP SCHEDULE
2021-08-29 10:23:25 +02:00
# Backups run on the given cron schedule in `busybox` flavor. If no
# value is set, `@daily` will be used. If you do not want the cron
# to ever run, use `0 0 5 31 2 ?`.
2021-04-02 14:17:09 +02:00
2021-08-29 10:23:25 +02:00
# BACKUP_CRON_EXPRESSION="0 2 * * *"
# The name of the backup file including the `.tar.gz` extension.
# Format verbs will be replaced as in `strftime`. Omitting them
2021-08-22 19:26:34 +02:00
# will result in the same filename for every backup run, which means previous
2021-08-29 10:23:25 +02:00
# versions will be overwritten on subsequent runs. The default results
# in filenames like `backup-2021-08-29T04-00-00.tar.gz`.
# BACKUP_FILENAME="backup-%Y-%m-%dT%H-%M-%S.tar.gz"
2021-04-02 14:17:09 +02:00
2021-12-22 14:39:46 +01:00
# Setting BACKUP_FILENAME_EXPAND to true allows for environment variable
2021-12-23 09:22:56 +01:00
# placeholders in BACKUP_FILENAME, BACKUP_LATEST_SYMLINK and in
# BACKUP_PRUNING_PREFIX that will get expanded at runtime,
# e.g. `backup-$HOSTNAME-%Y-%m-%dT%H-%M-%S.tar.gz`. Expansion happens before
# interpolating strftime tokens. It is disabled by default.
2021-12-22 14:39:46 +01:00
# Please note that you will need to escape the `$` when providing the value
# in a docker-compose.yml file, i.e. using $$VAR instead of $VAR.
2022-01-25 21:16:16 +01:00
# BACKUP_FILENAME_EXPAND="true"
2021-12-22 14:39:46 +01:00
2021-10-01 10:07:46 +02:00
# When storing local backups, a symlink to the latest backup can be created
# in case a value is given for this key. This has no effect on remote backups.
# BACKUP_LATEST_SYMLINK="backup.latest.tar.gz"
2021-11-08 08:44:59 +01:00
# Whether to copy the content of backup folder before creating the tar archive.
# In the rare scenario where the content of the source backup volume is continously
# updating, but we do not wish to stop the container while performing the backup,
# this setting can be used to ensure the integrity of the tar.gz file.
2021-11-08 08:39:18 +01:00
# BACKUP_FROM_SNAPSHOT="false"
2021-04-02 14:17:09 +02:00
########### BACKUP STORAGE
2021-08-29 10:23:25 +02:00
# The name of the remote bucket that should be used for storing backups. If
# this is not set, no remote backups will be stored.
# AWS_S3_BUCKET_NAME="backup-bucket"
2022-01-25 21:16:16 +01:00
# If you want to store the backup in a non-root location on your bucket
# you can provide a path. The path must not contain a leading slash.
# AWS_S3_PATH="my/backup/location"
2021-04-02 14:17:09 +02:00
# Define credentials for authenticating against the backup storage and a bucket
2021-08-29 10:23:25 +02:00
# name. Although all of these keys are `AWS`-prefixed, the setup can be used
2021-04-02 14:17:09 +02:00
# with any S3 compatible storage.
2021-08-29 10:23:25 +02:00
# AWS_ACCESS_KEY_ID="<xxx>"
# AWS_SECRET_ACCESS_KEY="<xxx>"
2021-04-02 14:17:09 +02:00
2021-09-30 19:24:43 +02:00
# Instead of providing static credentials, you can also use IAM instance profiles
# or similar to provide authentication. Some possible configuration options on AWS:
# - EC2: http://169.254.169.254
# - ECS: http://169.254.170.2
# AWS_IAM_ROLE_ENDPOINT="http://169.254.169.254"
2021-04-02 14:17:09 +02:00
# This is the FQDN of your storage server, e.g. `storage.example.com`.
2022-02-02 17:22:42 +01:00
# Do not set this when working against AWS S3 (the default value is
2021-08-29 10:23:25 +02:00
# `s3.amazonaws.com`). If you need to set a specific (non-https) protocol, you
# will need to use the option below.
2021-08-19 09:25:53 +02:00
2021-08-29 10:23:25 +02:00
# AWS_ENDPOINT="storage.example.com"
2021-04-02 14:17:09 +02:00
2021-08-17 19:49:51 +02:00
# The protocol to be used when communicating with your storage server.
# Defaults to "https". You can set this to "http" when communicating with
# a different Docker container on the same host for example.
2021-08-19 09:25:53 +02:00
2021-08-17 19:49:51 +02:00
# AWS_ENDPOINT_PROTO="https"
2021-08-29 10:23:25 +02:00
# Setting this variable to `true` will disable verification of
2021-08-22 19:26:34 +02:00
# SSL certificates. You shouldn't use this unless you use self-signed
2021-10-28 19:55:39 +02:00
# certificates for your remote storage backend. This can only be used
# when AWS_ENDPOINT_PROTO is set to `https`.
2021-08-22 19:26:34 +02:00
# AWS_ENDPOINT_INSECURE="true"
2022-01-22 13:35:13 +01:00
# You can also backup files to any WebDAV server:
2022-01-22 13:29:21 +01:00
# The URL of the remote WebDAV server
# WEBDAV_URL="https://webdav.example.com"
# The Directory to place the backups to on the WebDAV server.
2022-01-22 13:35:13 +01:00
# If the path is not present on the server it will be created.
2022-01-22 13:29:21 +01:00
# WEBDAV_PATH="/my/directory/"
# The username for the WebDAV server
# WEBDAV_USERNAME="user"
# The password for the WebDAV server
# WEBDAV_PASSWORD="password"
2021-08-29 10:23:25 +02:00
# In addition to storing backups remotely, you can also keep local copies.
# Pass a container-local path to store your backups if needed. You also need to
# mount a local folder or Docker volume into that location (`/archive`
# by default) when running the container. In case the specified directory does
# not exist (nothing is mounted) in the container when the backup is running,
# local backups will be skipped. Local paths are also be subject to pruning of
# old backups as defined below.
2021-08-19 09:25:53 +02:00
# BACKUP_ARCHIVE="/archive"
2021-04-02 14:17:09 +02:00
########### BACKUP PRUNING
2021-08-19 09:25:53 +02:00
# **IMPORTANT, PLEASE READ THIS BEFORE USING THIS FEATURE**:
2021-08-29 10:23:25 +02:00
# The mechanism used for pruning old backups is not very sophisticated
2021-08-19 13:41:19 +02:00
# and applies its rules to **all files in the target directory** by default,
2021-08-19 09:25:53 +02:00
# which means that if you are storing your backups next to other files,
# these might become subject to deletion too. When using this option
# make sure the backup files are stored in a directory used exclusively
2021-08-29 10:23:25 +02:00
# for such files, or to configure BACKUP_PRUNING_PREFIX to limit
2021-08-19 13:41:19 +02:00
# removal to certain files.
2021-08-19 09:25:53 +02:00
2021-08-29 10:23:25 +02:00
# Define this value to enable automatic rotation of old backups. The value
2021-04-02 14:17:09 +02:00
# declares the number of days for which a backup is kept.
# BACKUP_RETENTION_DAYS="7"
2021-04-08 17:24:44 +02:00
# In case the duration a backup takes fluctuates noticeably in your setup
# you can adjust this setting to make sure there are no race conditions
2021-08-22 19:26:34 +02:00
# between the backup finishing and the rotation not deleting backups that
2021-08-29 10:23:25 +02:00
# sit on the edge of the time window. Set this value to a duration
2021-04-08 17:24:44 +02:00
# that is expected to be bigger than the maximum difference of backups.
2021-08-29 10:23:25 +02:00
# Valid values have a suffix of (s)econds, (m)inutes or (h)ours. By default,
# one minute is used.
2021-04-08 17:24:44 +02:00
2021-08-22 21:06:51 +02:00
# BACKUP_PRUNING_LEEWAY="1m"
2021-04-08 17:24:44 +02:00
2021-08-19 13:41:19 +02:00
# In case your target bucket or directory contains other files than the ones
# managed by this container, you can limit the scope of rotation by setting
# a prefix value. This would usually be the non-parametrized part of your
# BACKUP_FILENAME. E.g. if BACKUP_FILENAME is `db-backup-%Y-%m-%dT%H-%M-%S.tar.gz`,
# you can set BACKUP_PRUNING_PREFIX to `db-backup-` and make sure
2021-08-29 10:23:25 +02:00
# unrelated files are not affected by the rotation mechanism.
2021-08-19 13:41:19 +02:00
# BACKUP_PRUNING_PREFIX="backup-"
2021-04-02 14:17:09 +02:00
########### BACKUP ENCRYPTION
2021-08-29 10:23:25 +02:00
# Backups can be encrypted using gpg in case a passphrase is given.
2021-04-02 14:17:09 +02:00
# GPG_PASSPHRASE="<xxx>"
2021-05-24 20:34:30 +02:00
2021-06-26 21:16:22 +02:00
########### STOPPING CONTAINERS DURING BACKUP
# Containers can be stopped by applying a
# `docker-volume-backup.stop-during-backup` label. By default, all containers
# that are labeled with `true` will be stopped. If you need more fine grained
# control (e.g. when running multiple containers based on this image), you can
# override this default by specifying a different value here.
# BACKUP_STOP_CONTAINER_LABEL="service1"
2021-09-09 08:58:03 +02:00
2021-12-17 17:44:22 +01:00
########### NOTIFICATIONS
2021-12-17 08:31:28 +01:00
2021-12-17 17:44:22 +01:00
# Notifications (email, Slack, etc.) can be sent out when a backup run finishes.
2021-12-17 08:31:28 +01:00
# Configuration is provided as a comma-separated list of URLs as consumed
# by `shoutrrr`: https://containrrr.dev/shoutrrr/v0.5/services/overview/
2022-02-12 20:34:51 +01:00
# The content of such notifications can be customized. Dedicated documentation
# on how to do this can be found in the README. When providing multiple URLs or
# an URL that contains a comma, the values can be URL encoded to avoid ambiguities.
2021-12-17 08:31:28 +01:00
# The below URL demonstrates how to send an email using the provided SMTP
# configuration and credentials.
# NOTIFICATION_URLS=smtp://username:password@host:587/?fromAddress=sender@example.com&toAddresses=recipient@example.com
2021-12-18 10:23:07 +01:00
# By default, notifications would only be sent out when a backup run fails
# To receive notifications for every run, set `NOTIFICATION_LEVEL` to `info`
# instead of the default `error`.
2021-12-17 17:44:22 +01:00
2021-12-18 10:23:07 +01:00
# NOTIFICATION_LEVEL="error"
2021-12-17 17:44:22 +01:00
########### EMAIL NOTIFICATIONS
2021-09-09 08:58:03 +02:00
2021-12-17 08:31:28 +01:00
# ************************************************************************
# Providing notification configuration like this has been deprecated
2021-12-17 17:44:22 +01:00
# and will be removed in the next major version. Please use NOTIFICATION_URLS
2021-12-17 08:31:28 +01:00
# as documented above instead.
# ************************************************************************
2021-12-17 17:44:22 +01:00
# In case SMTP credentials are provided, notification emails can be sent out when
# a backup run finished. These emails will contain the start time, the error
# message on failure and all prior log output.
2021-09-09 08:58:03 +02:00
# The recipient(s) of the notification. Supply a comma separated list
# of adresses if you want to notify multiple recipients. If this is
# not set, no emails will be sent.
# EMAIL_NOTIFICATION_RECIPIENT="you@example.com"
# The "From" header of the sent email. Defaults to `noreply@nohost`.
# EMAIL_NOTIFICATION_SENDER="no-reply@example.com"
2021-09-10 11:58:33 +02:00
# Configuration and credentials for the SMTP server to be used.
# EMAIL_SMTP_PORT defaults to 587.
2021-09-09 08:58:03 +02:00
# EMAIL_SMTP_HOST="posteo.de"
# EMAIL_SMTP_PASSWORD="<xxx>"
# EMAIL_SMTP_USERNAME="no-reply@example.com"
# EMAIL_SMTP_PORT="<port>"
2021-04-02 14:17:09 +02:00
```
2021-12-18 13:24:14 +01:00
In case you encouter double quoted values in your configuration you might be running an [older version of `docker-compose` ].
You can work around this by either updating `docker-compose` or unquoting your configuration values.
[compose-issue]: https://github.com/docker/compose/issues/2854
2021-08-29 10:23:25 +02:00
## How to
### Stopping containers during backup
2021-04-02 14:17:09 +02:00
2021-08-29 10:23:25 +02:00
In many cases, it will be desirable to stop the services that are consuming the volume you want to backup in order to ensure data integrity.
This image can automatically stop and restart containers and services (in case you are running Docker in Swarm mode).
By default, any container that is labeled `docker-volume-backup.stop-during-backup=true` will be stopped before the backup is being taken and restarted once it has finished.
In case you need more fine grained control about which containers should be stopped (e.g. when backing up multiple volumes on different schedules), you can set the `BACKUP_STOP_CONTAINER_LABEL` environment variable and then use the same value for labeling:
2021-04-02 14:17:09 +02:00
```yml
version: '3'
services:
2021-08-29 10:23:25 +02:00
app:
# definition for app ...
2021-04-02 14:17:09 +02:00
labels:
2021-08-29 10:23:25 +02:00
- docker-volume-backup.stop-during-backup=service1
2021-04-02 14:17:09 +02:00
backup:
image: offen/docker-volume-backup:latest
2021-08-29 10:23:25 +02:00
environment:
BACKUP_STOP_CONTAINER_LABEL: service1
2021-04-02 14:17:09 +02:00
volumes:
2021-08-29 10:23:25 +02:00
- data:/backup/my-app-backup:ro
2021-04-02 14:17:09 +02:00
- /var/run/docker.sock:/var/run/docker.sock:ro
2021-08-29 10:23:25 +02:00
volumes:
data:
```
### Automatically pruning old backups
When `BACKUP_RETENTION_DAYS` is configured, the image will check if there are any backups in the remote bucket or local archive that are older than the given retention value and rotate these backups away.
Be aware that this mechanism looks at __all files in the target bucket or archive__ , which means that other files that are older than the given deadline are deleted as well. In case you need to use a target that cannot be used exclusively for your backups, you can configure `BACKUP_PRUNING_PREFIX` to limit which files are considered eligible for deletion:
```yml
version: '3'
services:
# ... define other services using the `data` volume here
backup:
image: offen/docker-volume-backup:latest
environment:
BACKUP_FILENAME: backup-%Y-%m-%dT%H-%M-%S.tar.gz
BACKUP_PRUNING_PREFIX: backup-
BACKUP_RETENTION_DAYS: 7
volumes:
- ${HOME}/backups:/archive
2021-04-02 14:17:09 +02:00
- data:/backup/my-app-backup:ro
2021-08-29 10:23:25 +02:00
- /var/run/docker.sock:/var/run/docker.sock:ro
2021-04-02 14:17:09 +02:00
volumes:
data:
```
2021-09-09 08:58:03 +02:00
### Send email notifications on failed backup runs
To send out email notifications on failed backup runs, provide SMTP credentials, a sender and a recipient:
```yml
version: '3'
services:
backup:
image: offen/docker-volume-backup:latest
environment:
# ... other configuration values go here
2021-12-17 08:31:28 +01:00
NOTIFICATION_URLS=smtp://me:secret@smtp.example.com:587/?fromAddress=no-reply@example.com& toAddresses=you@example.com
2021-09-09 08:58:03 +02:00
```
2021-12-18 10:23:07 +01:00
Notification backends other than email are also supported.
Refer to the documentation of [shoutrrr][shoutrrr-docs] to find out about options and configuration.
[shoutrrr-docs]: https://containrrr.dev/shoutrrr/v0.5/services/overview/
2022-02-11 20:05:16 +01:00
### Customize notifications
The title and body of the notifications can be easily tailored to your needs using [go templates ](https://pkg.go.dev/text/template ).
Templates must be mounted inside the container in `/etc/dockervolumebackup/notifications.d/` : any file inside this directory will be parsed.
The files have to define [nested templates ](https://pkg.go.dev/text/template#hdr-Nested_template_definitions ) in order to override the original values. An example:
```
{{ define "title_success" -}}
✅ Successfully ran backup {{ .Config.BackupStopContainerLabel }}
{{- end }}
{{ define "body_success" -}}
▶️ Start time: {{ .Stats.StartTime | formatTime }}
⏹️ End time: {{ .Stats.EndTime | formatTime }}
⌛ Took time: {{ .Stats.TookTime }}
🛑 Stopped containers: {{ .Stats.Containers.Stopped }}/{{ .Stats.Containers.All }} ({{ .Stats.Containers.StopErrors }} errors)
⚖️ Backup size: {{ .Stats.BackupFile.Size | formatBytesBin }} / {{ .Stats.BackupFile.Size | formatBytesDec }}
🗑️ Pruned backups: {{ .Stats.Storages.Local.Pruned }}/{{ .Stats.Storages.Local.Total }} ({{ .Stats.Storages.Local.PruneErrors }} errors)
{{- end }}
```
Overridable template names are: `title_success` , `body_success` , `title_failure` , `body_failure` .
For a full list of available variables and functions, see [this page ](https://github.com/offen/docker-volume-backup/blob/master/docs/NOTIFICATION-TEMPLATES.md ).
2021-12-18 10:23:07 +01:00
2021-08-29 10:23:25 +02:00
### Encrypting your backup using GPG
2021-07-08 18:39:49 +02:00
2021-08-29 10:23:25 +02:00
The image supports encrypting backups using GPG out of the box.
In case a `GPG_PASSPHRASE` environment variable is set, the backup will be encrypted using the given key and saved as a `.gpg` file instead.
Assuming you have `gpg` installed, you can decrypt such a backup using (your OS will prompt for the passphrase before decryption can happen):
```console
gpg -o backup.tar.gz -d backup.tar.gz.gpg
```
### Restoring a volume from a backup
In case you need to restore a volume from a backup, the most straight forward procedure to do so would be:
- Stop the container(s) that are using the volume
- Untar the backup you want to restore
```console
tar -C /tmp -xvf backup.tar.gz
```
2022-02-04 11:52:59 +01:00
- Using a temporary once-off container, mount the volume (the example assumes it's named `data` ) and copy over the backup. Make sure you copy the correct path level (this depends on how you mount your volume into the backup container), you might need to strip some leading elements
2021-08-29 10:23:25 +02:00
```console
2022-02-04 11:52:59 +01:00
docker run -d --name temp_restore_container -v data:/backup_restore alpine
docker cp /tmp/backup/data-backup temp_restore_container:/backup_restore
docker stop temp_restore_container
docker rm temp_restore_container
2021-08-29 10:23:25 +02:00
```
2022-02-02 17:22:42 +01:00
- Restart the container(s) that are using the volume
2021-08-29 10:23:25 +02:00
Depending on your setup and the application(s) you are running, this might involve other steps to be taken still.
2021-10-23 17:45:57 +02:00
### Set the timezone the container runs in
2021-10-23 17:44:30 +02:00
By default a container based on this image will run in the UTC timezone.
As the image is designed to be as small as possible, additional timezone data is not included.
In case you want to run your cron rules in your local timezone (respecting DST and similar), you can mount your Docker host's `/etc/timezone` and `/etc/localtime` in read-only mode:
2021-10-23 17:45:57 +02:00
```yml
2021-10-23 17:44:30 +02:00
version: '3'
services:
backup:
image: offen/docker-volume-backup:latest
volumes:
- data:/backup/my-app-backup:ro
- /etc/timezone:/etc/timezone:ro
- /etc/localtime:/etc/localtime:ro
volumes:
data:
```
2021-08-29 10:23:25 +02:00
### Using with Docker Swarm
By default, Docker Swarm will restart stopped containers automatically, even when manually stopped.
If you plan to have your containers / services stopped during backup, this means you need to apply the `on-failure` restart policy to your service's definitions.
A restart policy of `always` is not compatible with this tool.
2021-07-08 18:39:49 +02:00
2021-08-05 21:56:19 +02:00
---
2021-08-18 20:38:51 +02:00
When running in Swarm mode, it's also advised to set a hard memory limit on your service (~25MB should be enough in most cases, but if you backup large files above half a gigabyte or similar, you might have to raise this in case the backup exits with `Killed` ):
2021-08-05 21:56:19 +02:00
```yml
services:
backup:
image: offen/docker-volume-backup:latest
deployment:
resources:
limits:
memory: 25M
```
2021-08-29 10:23:25 +02:00
### Manually triggering a backup
2021-07-11 10:36:29 +02:00
You can manually trigger a backup run outside of the defined cron schedule by executing the `backup` command inside the container:
```
docker exec < container_ref > backup
```
2021-12-17 08:31:28 +01:00
### Update deprecated email configuration
Starting with version 2.6.0, configuring email notifications using `EMAIL_*` keys has been deprecated.
Instead of providing multiple values using multiple keys, you can now provide a single URL for `NOTIFICATION_URLS` .
Before:
```ini
EMAIL_NOTIFICATION_RECIPIENT="you@example.com"
EMAIL_NOTIFICATION_SENDER="no-reply@example.com"
EMAIL_SMTP_HOST="posteo.de"
EMAIL_SMTP_PASSWORD="secret"
EMAIL_SMTP_USERNAME="me"
EMAIL_SMTP_PORT="587"
```
After:
```ini
NOTIFICATION_URLS=smtp://me:secret@posteo.de:587/?fromAddress=no-reply@example.com& toAddresses=you@example.com
```
2021-08-29 10:23:25 +02:00
## Recipes
This section lists configuration for some real-world use cases that you can mix and match according to your needs.
### Backing up to AWS S3
```yml
version: '3'
services:
# ... define other services using the `data` volume here
backup:
image: offen/docker-volume-backup:latest
environment:
AWS_BUCKET_NAME: backup-bucket
AWS_ACCESS_KEY_ID: AKIAIOSFODNN7EXAMPLE
AWS_SECRET_ACCESS_KEY: wJalrXUtnFEMI/K7MDENG/bPxRfiCYEXAMPLEKEY
volumes:
- data:/backup/my-app-backup:ro
- /var/run/docker.sock:/var/run/docker.sock:ro
volumes:
data:
```
2022-02-02 17:22:42 +01:00
### Backing up to Filebase
```yml
version: '3'
services:
# ... define other services using the `data` volume here
backup:
image: offen/docker-volume-backup:latest
environment:
AWS_ENDPOINT: s3.filebase.com
AWS_BUCKET_NAME: filebase-bucket
AWS_ACCESS_KEY_ID: FILEBASE-ACCESS-KEY
AWS_SECRET_ACCESS_KEY: FILEBASE-SECRET-KEY
volumes:
- data:/backup/my-app-backup:ro
- /var/run/docker.sock:/var/run/docker.sock:ro
volumes:
data:
```
2021-08-29 10:23:25 +02:00
### Backing up to MinIO
```yml
version: '3'
services:
# ... define other services using the `data` volume here
backup:
image: offen/docker-volume-backup:latest
environment:
AWS_ENDPOINT: minio.example.com
AWS_BUCKET_NAME: backup-bucket
AWS_ACCESS_KEY_ID: MINIOACCESSKEY
AWS_SECRET_ACCESS_KEY: MINIOSECRETKEY
volumes:
- data:/backup/my-app-backup:ro
- /var/run/docker.sock:/var/run/docker.sock:ro
volumes:
data:
```
2022-01-22 13:29:21 +01:00
### Backing up to WebDAV
```yml
version: '3'
services:
# ... define other services using the `data` volume here
backup:
image: offen/docker-volume-backup:latest
environment:
WEBDAV_URL: https://webdav.mydomain.me
WEBDAV_PATH: /my/directory/
WEBDAV_USERNAME: user
WEBDAV_PASSWORD: password
volumes:
- data:/backup/my-app-backup:ro
- /var/run/docker.sock:/var/run/docker.sock:ro
volumes:
data:
```
2021-08-29 10:23:25 +02:00
### Backing up locally
```yml
version: '3'
services:
# ... define other services using the `data` volume here
backup:
image: offen/docker-volume-backup:latest
2021-10-01 10:07:46 +02:00
environment:
BACKUP_FILENAME: backup-%Y-%m-%dT%H-%M-%S.tar.gz
BACKUP_LATEST_SYMLINK: backup-latest.tar.gz
2021-08-29 10:23:25 +02:00
volumes:
- data:/backup/my-app-backup:ro
- /var/run/docker.sock:/var/run/docker.sock:ro
- ${HOME}/backups:/archive
volumes:
data:
```
### Backing up to AWS S3 as well as locally
```yml
version: '3'
services:
# ... define other services using the `data` volume here
backup:
image: offen/docker-volume-backup:latest
environment:
AWS_BUCKET_NAME: backup-bucket
AWS_ACCESS_KEY_ID: AKIAIOSFODNN7EXAMPLE
AWS_SECRET_ACCESS_KEY: wJalrXUtnFEMI/K7MDENG/bPxRfiCYEXAMPLEKEY
volumes:
- data:/backup/my-app-backup:ro
- /var/run/docker.sock:/var/run/docker.sock:ro
- ${HOME}/backups:/archive
volumes:
data:
```
### Running on a custom cron schedule
```yml
version: '3'
services:
# ... define other services using the `data` volume here
backup:
image: offen/docker-volume-backup:latest
environment:
# take a backup on every hour
BACKUP_CRON_EXPRESSION: "0 * * * * "
AWS_BUCKET_NAME: backup-bucket
AWS_ACCESS_KEY_ID: AKIAIOSFODNN7EXAMPLE
AWS_SECRET_ACCESS_KEY: wJalrXUtnFEMI/K7MDENG/bPxRfiCYEXAMPLEKEY
volumes:
- data:/backup/my-app-backup:ro
- /var/run/docker.sock:/var/run/docker.sock:ro
volumes:
data:
```
### Rotating away backups that are older than 7 days
```yml
version: '3'
services:
# ... define other services using the `data` volume here
backup:
image: offen/docker-volume-backup:latest
environment:
AWS_BUCKET_NAME: backup-bucket
AWS_ACCESS_KEY_ID: AKIAIOSFODNN7EXAMPLE
AWS_SECRET_ACCESS_KEY: wJalrXUtnFEMI/K7MDENG/bPxRfiCYEXAMPLEKEY
BACKUP_FILENAME: backup-%Y-%m-%dT%H-%M-%S.tar.gz
BACKUP_PRUNING_PREFIX: backup-
BACKUP_RETENTION_DAYS: 7
volumes:
- data:/backup/my-app-backup:ro
- /var/run/docker.sock:/var/run/docker.sock:ro
volumes:
data:
```
### Encrypting your backups using GPG
```yml
version: '3'
services:
# ... define other services using the `data` volume here
backup:
image: offen/docker-volume-backup:latest
environment:
AWS_BUCKET_NAME: backup-bucket
AWS_ACCESS_KEY_ID: AKIAIOSFODNN7EXAMPLE
AWS_SECRET_ACCESS_KEY: wJalrXUtnFEMI/K7MDENG/bPxRfiCYEXAMPLEKEY
GPG_PASSPHRASE: somesecretstring
volumes:
- data:/backup/my-app-backup:ro
- /var/run/docker.sock:/var/run/docker.sock:ro
volumes:
data:
```
### Running multiple instances in the same setup
```yml
version: '3'
services:
# ... define other services using the `data_1` and `data_2` volumes here
backup_1: & backup_service
image: offen/docker-volume-backup:latest
environment: & backup_environment
BACKUP_CRON_EXPRESSION: "0 2 * * *"
AWS_BUCKET_NAME: backup-bucket
AWS_ACCESS_KEY_ID: AKIAIOSFODNN7EXAMPLE
AWS_SECRET_ACCESS_KEY: wJalrXUtnFEMI/K7MDENG/bPxRfiCYEXAMPLEKEY
# Label the container using the `data_1` volume as `docker-volume-backup.stop-during-backup=service1`
BACKUP_STOP_CONTAINER_LABEL: service1
volumes:
- data_1:/backup/data-1-backup:ro
- /var/run/docker.sock:/var/run/docker.sock:ro
backup_2:
< < : * backup_service
environment:
< < : * backup_environment
# Label the container using the `data_2` volume as `docker-volume-backup.stop-during-backup=service2`
BACKUP_CRON_EXPRESSION: "0 3 * * *"
BACKUP_STOP_CONTAINER_LABEL: service2
volumes:
- data_2:/backup/data-2-backup:ro
- /var/run/docker.sock:/var/run/docker.sock:ro
volumes:
data_1:
data_2:
```
2021-07-08 18:39:49 +02:00
2021-04-02 14:17:09 +02:00
## Differences to `futurice/docker-volume-backup`
2021-10-01 08:48:20 +02:00
This image is heavily inspired by `futurice/docker-volume-backup` . We decided to publish this image as a simpler and more lightweight alternative because of the following requirements:
2021-04-02 14:17:09 +02:00
2021-08-29 10:23:25 +02:00
- The original image is based on `ubuntu` and requires additional tools, making it heavy.
This version is roughly 1/25 in compressed size (it's ~12MB).
- The original image uses a shell script, when this version is written in Go, which makes it easier to extend and maintain (more verbose too).
- The original image proposed to handle backup rotation through AWS S3 lifecycle policies.
This image adds the option to rotate away old backups through the same command so this functionality can also be offered for non-AWS storage backends like MinIO.
Local copies of backups can also be pruned once they reach a certain age.
2021-08-23 08:19:22 +02:00
- InfluxDB specific functionality from the original image was removed.
2021-07-01 15:16:39 +02:00
- `arm64` and `arm/v7` architectures are supported.
2021-07-08 18:39:49 +02:00
- Docker in Swarm mode is supported.
2021-10-23 17:44:30 +02:00
- Notifications on failed backups are supported
- IAM authentication through instance profiles is supported