Skip to content
This repository has been archived by the owner on Feb 22, 2024. It is now read-only.

Docker image that runs a single cron job to sync files with S3 as defined via environment variables

License

Notifications You must be signed in to change notification settings

silinternational/docker-sync-with-s3

Repository files navigation

docker-sync-with-s3

Docker image that runs a single cron job to sync files with S3 as defined via environment variables.

This image can be used to either sync files from a container to S3 or from S3 to a container.

It is intended that a single instance of this image will run a single cron job and sync process. If you have multiple directories to sync, then you should run multiple containers each with the appropriate configuration for that directory.

Docker Hub

This image is built automatically on the Docker Hub as silintl/sync-with-s3

Running locally

  1. Clone this repo
  2. Copy local.env.dist to local.env and update values as appropriate
  3. Run docker-compose up -d

Expected Environment Variables

  1. ACCESS_KEY - AWS Access Key
  2. SECRET_KEY - AWS Secret Access Key
  3. CRON_SCHEDULE - Schedule for cron job, for every 15 minutes it would be: */15 * * * *
  4. SOURCE_PATH - Source files to be synced, example: /var/www/uploads
  5. DESTINATION_PATH - Destination of where to sync files to, example: s3://my-bucket/site-uploads
  6. BUCKET_LOCATION - AWS Region for bucket, ex: us-east-1
  7. LOGENTRIES_KEY - (optional) If provided, the image will send command output to syslog with priority user.info.
  8. S3SYNC_ARGS - (optional) If provided, the arguments will be included in the aws s3 sync command. For example, setting S3SYNC_ARGS=--delete will cause files in the destination to be deleted if they no longer exist in the source.

Volumes

You will need to define volumes in your Docker configuration for sharing filesystem between your application containers and this sync container.

About

Docker image that runs a single cron job to sync files with S3 as defined via environment variables

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Contributors 3

  •  
  •  
  •