Document scale-up/down approach in docs

This commit is contained in:
Frederik Ring 2024-01-26 20:25:59 +01:00
parent b7855605d4
commit fee8cb234c
2 changed files with 53 additions and 5 deletions

View File

@ -7,12 +7,62 @@ nav_order: 13
# Use with Docker Swarm # Use with Docker Swarm
By default, Docker Swarm will restart stopped containers automatically, even when manually stopped. {: .note }
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. The mechanisms described in this page __do only apply when Docker is running in [Swarm mode][swarm]__.
A restart policy of `always` is not compatible with this tool.
[swarm]: https://docs.docker.com/engine/swarm/
## Stopping containers during backup
Stopping and restarting containers during backup creation when running Docker in Swarm mode is supported in two ways.
### Scaling services down to zero before scaling back up
When labeling a service in the `deploy` section, the following strategy for stopping and restarting will be used:
- The service is scaled down to zero replicas
- The backup is created
- The service is scaled back up to the previous number of replicas
{: .note }
This approach will only work for services that are deployed in __replicated mode__.
Such a service definition could look like:
```yml
services:
app:
image: myorg/myimage:latest
deploy:
labels:
- docker-volume-backup.stop-during-backup=true
replicas: 2
```
### Stopping the containers
This approach bypasses the services and stops containers directly, creates the backup and restarts the containers again.
As Docker Swarm would usually try to instantly restart containers that are manually stopped, this approach only works when using the `on-failure` restart policy.
A restart policy of `always` is not compatible with this approach.
Such a service definition could look like:
```yml
services:
app:
image: myapp/myimage:latest
labels:
- docker-volume-backup.stop-during-backup=true
deploy:
replicas: 2
restart_policy:
condition: on-failure
```
--- ---
## Memory limit considerations
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`): 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`):
```yml ```yml

View File

@ -35,8 +35,6 @@ services:
offen: offen:
image: offen/offen:latest image: offen/offen:latest
healthcheck:
disable: true
deploy: deploy:
labels: labels:
- docker-volume-backup.stop-during-backup=true - docker-volume-backup.stop-during-backup=true