Skip to content

mjyothul/mongodb-backup-s3

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

5 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

drahoslavzan/mongodb-backup-s3

Docker image which dumps all MongoDB databases to AWS S3.

This image will run mongodump on a selected host and put the result into an S3 bucket.

Environment variables

VAR DESCRIPTION
CRON_SCHEDULE Cron schedule, leave empty to disable cron job.
BACKUP_FILE Name of the backup file, e.g. mongodb
MONGO_URI DB connection string
AWS_ACCESS_KEY_ID AWS access key ID
AWS_SECRET_ACCESS_KEY AWS secret access key
AWS_DEFAULT_REGION AWS region, e.g. us-east-2
AWS_BUCKET_DIR AWS bucker directory, e.g. s3://myawsomebucket/backup

Examples

The example below will backup mongo database every day at 1 am. It will create /opt/backup/mongodb.tar.gz" file locally and upload it to S3 folder named /backup inside the myawesomebucket bucket.

version: '3'

services:
  mongodb:
    image: mongo:4.2
    container_name: mongodb
    restart: always
    expose:
      - '27017'
    volumes:
      - /opt/mongodb/db:/data/db
      - /opt/mongodb/mongo-init.sh:/docker-entrypoint-initdb.d/mongo-init.sh:ro
    networks:
      - mongodb
    environment:
      - MONGO_INITDB_ROOT_USERNAME=root
      - MONGO_INITDB_ROOT_PASSWORD=<MONGO_ROOT_PASS>

  mongodb-backup:
      image: drahoslavzan/mongodb-backup-s3:latest
      container_name: mongodb-backup
      restart: always
      volumes:
        - /opt/backup:/backup
      networks:
        - mongodb
      environment:
        - CRON_SCHEDULE=0 1 * * *
        - BACKUP_FILE=mongodb
        - MONGO_URI=root:<MONGO_ROOT_PASS>@mongodb:27017
        - AWS_ACCESS_KEY_ID=<AWS_KEY>
        - AWS_SECRET_ACCESS_KEY=<AWS_SECRET>
        - AWS_DEFAULT_REGION=us-east-2
        - AWS_BUCKET_DIR=s3://myawesomebucket/backup

networks:
  mongodb:

AWS S3 Configuration

  1. Create AWS account.
  2. Create S3 bucker in a region you want, choose a unique bucket name, e.g. myawesomebucket. You can leave all options in their default value, make sure you have enabled private access only.
  3. Create a folder inside the bucket called backup.
  4. Create the backup user with programmatic access.
  5. Create a new policy called BackupAccess and inside the json editor put the file below (do not forget to change myawesomebucket to your bucket name)
{
    "Version": "2012-10-17",
    "Statement": [
        {
            "Effect": "Allow",
            "Action": "s3:ListBucket",
            "Resource": "arn:aws:s3:::myawesomebucket"
        },
        {
            "Effect": "Allow",
            "Action": [
                "s3:PutObject",
                "s3:GetObject",
                "s3:DeleteObject"
            ],
            "Resource": "arn:aws:s3:::myawesomebucket/backup/*"
        }
    ]
}
  1. Assign BackupAccess policy to the backup user.
  2. Provide the bucket region and the backup user access and secret keys to the configuration (env variables).
  3. You are all set!

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Shell 80.4%
  • Dockerfile 19.6%