Docker Image with Alpine Linux, pg_dump and awscli for backup postgres database to s3
Run every day at 2 am
docker run -d --name pgdump \
-e "POSTGRESQL_URI=postgres://user:pass@host:port/dbname"
-e "AWS_ACCESS_KEY_ID=your_aws_access_key"
-e "AWS_SECRET_ACCESS_KEY=your_aws_secret_access_key"
-e "AWS_DEFAULT_REGION=us-west-1"
-e "S3_BUCKET=your_aws_bucket"
-e "BACKUP_CRON_SCHEDULE=0 2 * * *"
lgatica/pgdump-s3
docker run -d --name pgdump \
-e "POSTGRESQL_URI=postgres://user:pass@host:port/dbname"
-e "AWS_ACCESS_KEY_ID=your_aws_access_key"
-e "AWS_SECRET_ACCESS_KEY=your_aws_secret_access_key"
-e "AWS_DEFAULT_REGION=us-west-1"
-e "S3_BUCKET=your_aws_bucket"
lgatica/pgdump-s3
You need to add a user with the following policies. Be sure to change your_bucket
by the correct.
{
"Version": "2012-10-17",
"Statement": [
{
"Sid": "Stmt1412062044000",
"Effect": "Allow",
"Action": [
"s3:PutObject",
"s3:PutObjectAcl"
],
"Resource": [
"arn:aws:s3:::your_bucket/*"
]
},
{
"Sid": "Stmt1412062128000",
"Effect": "Allow",
"Action": [
"s3:ListBucket"
],
"Resource": [
"arn:aws:s3:::your_bucket"
]
}
]
}
MAX_BACKUPS
- Default not set. If set doing it keeps the last n backups in /backup