This utility lets you compress a folder and upload it to a AWS S3 bucket, once or periodically.
This software is young. It is not intended for production use yet. It has not been battle-tested yet.
Use at your own risks!
The CLI options will certainly change, but any breaking change will probably mean an increase in the minor version
number as per semver, until it reaches 1.0.0
. New features that are backwards-compatible will lead to patch number
bumps.
``` Usage: awsbck [OPTIONS] [FOLDER]
Arguments: [FOLDER] Path to the folder to backup [env: AWSBCK_FOLDER=]
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
:
version: '3.2'
volumes: database:
services: postgresql: image: postgres:14 restart: unless-stopped volumes: - type: volume source: database target: /var/lib/postgresql/data/ awsbck: image: vbersier/awsbck:root-latest # postgres uses UID 999 which can't be accessed as nonroot restart: unless-stopped volumes: - type: volume source: database target: /database readonly: true environment: AWSBCKFOLDER: /database AWSBCKINTERVAL: 86400 # every 24h AWSREGION: eu-central-1 AWSBUCKET: mybucket AWSACCESSKEYID: $AWSACCESSKEYID AWSSECRETACCESSKEY: $AWSSECRETACCESSKEY ```