Create a gist now

Instantly share code, notes, and snippets.

What would you like to do?
AWS backup folder from command-line with compression and encryption
### Install Python and aws
[pip install awscli](
You may need to add it to your path, e.g. export PATH="$PATH:/home/player/.local/bin"
### Setup AWS S3 bucket
* In S3, create a new backup bucket. You may wish to set it up with versioning and lifecycle management rules so that you can just keep pushing to the same object and old versions will be deleted and/or moved to Glacier. Also recommended to establish tags and logging if cost is likely to be significant and therefore should be tracked.
* In IAM, create a programmatic user and ensure it has an access key and secret access key
* In IAM, give this user "ALLOW" access to the S3 bucket
* In S3, under policies, set a policy to give this user write-only access
### Configure the client
> aws configure
Enter credentials from above
### Make a gpg password
Add a long random string to /home/me/gpg_pass
### Pipe to S3!
> tar c data | gpg --no-use-agent -c --passphrase=/home/me/gpg_pass | aws s3 cp - s3://backups/backup.txt
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment