This project will copy public DockerHub repositories to a private registry.
It's possible to filter by docker tags, tag age and number of latest tags.
- make sure you got Go 1.10 or newer
- OSX:
brew install go
- OSX:
- make sure you got
godepinstalled- OSX:
brew install dep
- OSX:
- make sure you have
CGOenabledexport CGO_ENABLED=1
- clone this repository to
$HOME/src/github.com/seatgeek/docker-mirror - change your working directory to
$HOME/go/src/github.com/seatgeek/docker-mirror - run
dep ensure -vendor-onlyto install dependencies - run
go installto build and install thedocker-mirrorbinary into your$HOME/go/bin/directory- alternative:
go buildto build the binary and put it in the current working directory
- alternative:
Make sure that your local Docker agent is logged into to ECR (eval $(aws ecr get-login --no-include-email --region us-east-1))
docker-mirror will automatically create the ECR repository on demand, so you do not need to login and do any UI operations in the AWS Console.
docker-mirror will look for your AWS credentials in all the default locations (env, ~/.aws/ and so forth like normal AWS tools do)
- add the new repository to the
config.yamlfile- TIP: omit the
max_tag_agefor the initial sync to mirror all historic tags (match_tagis fine to use in all cases)
- TIP: omit the
- run
PREFIX=${reopsitory_name} docker-mirrorto trigger a sync for the specific new repository (you probably don't want to sync all the existing repositories) - add the
max_tag_agefilter to the newly added repository so future syns won't cosider all historic tags
- run
PREFIX=${reopsitory_name} docker-mirrorto trigger a sync for the specific repository- TIP: Consider if the tags you want to sync fits within the
max_tag_ageand other filters
- TIP: Consider if the tags you want to sync fits within the
- run
docker-mirrorand wait (for a while)
---
target:
# where to copy images to
registry: ACCOUNT_ID.dkr.REGION.amazonaws.com
# (optional) prefix all repositories with this name
# ACCOUNT_ID.dkr.REGION.amazonaws.com/hub/jippi/hashi-ui
prefix: "hub/"
# what repositories to copy
repositories:
# will automatically know it's a "library" repository in dockerhub
- name: elasticsearch
match_tag: # tags to match, can be specific or glob pattern
- "5.6.8" # specific tag match
- "6.*" # glob patterns will match
ignore_tag: # tags to never match on (even if its matched by `tag`)
- "*-alpine" # support both glob or specific strings
- name: yotpo/resec
max_tag_age: 8w # only import tags that are 8w or less old
- name: jippi/hashi-ui
max_tags: 10 # only copy the 10 latest tags
match_tag:
- "v*"
- name: jippi/go-metadataproxy # import all tags| Environment Variable | Default | Description |
|---|---|---|
| CONFIG_FILE | config.yaml | config file to use |
| DOCKERHUB_USER | unset | optional user to authenticate to docker hub with |
| DOCKERHUB_PASSWORD | unset | optional password to authenticate to docker hub with |