This utility lets you compress a folder and upload it to a AWS S3 bucket, once or periodically.
This software is in a beta stage and, although it has not caused any problems in testing, I wouldn't recommend it for production use.
Use at your own risks!
The CLI will certainly change, but any breaking change should mean an increase in the minor version number as per semver
, until it reaches 1.0.0
. New features that are backwards-compatible and bug fixes will lead to patch number bumps
until then.
```
Usage: awsbck [OPTIONS] --bucket
Arguments:
Options:
-i, --interval
CLI arguments take precedence over environment variables.
The --filename
option accepts ASCII alphanumeric characters and !-_.*'()/
. Other characters will be discarded.
```shell
$ cat .env AWSREGION="eu-central-1" AWSACCESSKEYID="YOURKEYID" AWSSECRETACCESS_KEY="yoursecret"
$ awsbck -i 3600 -b mybucket /myfolder ```
$ export AWS_REGION="eu-central-1"
$ export AWS_ACCESS_KEY_ID="YOUR_KEY_ID"
$ export AWS_SECRET_ACCESS_KEY="yoursecret"
$ docker run \
--rm \
--mount type=bind,src="$(pwd)"/target,dst=/target,readonly \
-e AWS_REGION -e AWS_ACCESS_KEY_ID -e AWS_SECRET_ACCESS_KEY \
vbersier/awsbck:latest \
-i 3600 -b my_bucket /target
Check out the releases for prebuilt binaries.
shell
$ cargo install awsbck
This utility is available as a docker image vbersier/awsbck
.
There are two tag variants, one running as a non-root user (latest
) and one as a root user (root-latest
).
This image is particularly useful to backup named volumes in docker. If you encounter problems where the awsbck
logs
report a permissions problem, then you can try to switch to the root-latest
tag.
Below an example of using it with docker compose
. In order to make sure the backup happens properly, we can't just
copy the db data, as it might be in the middle of a write or other operation. Thus we send the pg_dumpall
command
and store the resulting dump to a separate volume that we can backup to S3.
version: '3.2'
volumes: # the first volume is to persist the database raw data database: # this volume will be used to share the dump file with awsbck database-backup:
services:
postgresql:
image: postgres:14
restart: unless-stopped
volumes:
- type: volume
source: database
target: /var/lib/postgresql/data/
- type: volume
source: database-backup
target: /backup
# this service will send a dump command to the postgres container periodically (here 6h)
# and store the resulting file in the database-backup
volume mounted at /backup
postgres-backup:
image: docker:cli
containername: postgresbackup
volumes:
- type: bind
source: /var/run/docker.sock
target: /var/run/docker.sock
command:
[
'/bin/sh',
'-c',
'while true; do sleep 21600; docker exec -t postgres pgdumpall -c -U postgres > /backup/dumpdatabase.sql; done'
]
# we mount the backup volume as read-only and back up the SQL dump every 24h
awsbck:
image: vbersier/awsbck:latest
restart: unless-stopped
volumes:
- type: volume
source: database-backup
target: /database
readonly: true
environment:
AWSBCKFOLDER: /database
AWSBCKINTERVAL: 86400
AWSREGION: eu-central-1
AWSBUCKET: mybucket
AWSACCESSKEYID: $AWSACCESSKEYID
AWSSECRETACCESSKEY: $AWSSECRETACCESSKEY
```