Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/containersolutions/imagewolf
Fast Distribution of Docker Images on Clusters
https://github.com/containersolutions/imagewolf
docker docker-image docker-registry swarm
Last synced: 3 months ago
JSON representation
Fast Distribution of Docker Images on Clusters
- Host: GitHub
- URL: https://github.com/containersolutions/imagewolf
- Owner: ContainerSolutions
- Created: 2016-12-20T14:33:31.000Z (about 8 years ago)
- Default Branch: master
- Last Pushed: 2017-11-02T23:32:01.000Z (about 7 years ago)
- Last Synced: 2024-08-02T15:48:24.944Z (6 months ago)
- Topics: docker, docker-image, docker-registry, swarm
- Language: Go
- Homepage:
- Size: 16.5 MB
- Stars: 134
- Watchers: 9
- Forks: 14
- Open Issues: 5
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
ImageWolf - Fast Distribution of Docker Images on Clusters
==========================================================ImageWolf is a PoC that provides a blazingly fast way to get Docker images
loaded onto your cluster, allowing updates to be pushed out quicker.ImageWolf works alongside existing registries such as the Docker Hub, Quay.io
as well as self-hosted registries.The PoC for ImageWolf uses the BitTorrent protocol spread images around the
cluster as they are pushed.## Video
### Docker Swarm
[![asciicast](https://asciinema.org/a/DowEjf7Inqhtu4ZQsvZfA2b0j.png)](https://asciinema.org/a/DowEjf7Inqhtu4ZQsvZfA2b0j)
### Kubernetes
[![asciicast](https://asciinema.org/a/01rQtDxr67y4Gtu85KpBJ9cz2.png)](https://asciinema.org/a/01rQtDxr67y4Gtu85KpBJ9cz2)
## Getting Started
ImageWolf is currently alpha software and intended as a PoC - please don't run it in
production!### Docker Swarm Mode
To start ImageWolf, run the following on your Swarm master:
```
docker network create -d overlay --attachable wolf
docker service create --network wolf --name imagewolf --mode global \
--mount type=bind,src=/var/run/docker.sock,dst=/var/run/docker.sock \
containersol/imagewolf
```The ImageWolf service is now running on all nodes in our cluster.
The next step is to link ImageWolf with a registry. Whenever an image is pushed to
the registry, ImageWolf will immediately pull it and distribute across all the
nodes. To set up a private registry linked to ImageWolf:```
# First find the id of the ImageWolf task running on this node
# This should work, but is a bit of a hack
TASK=$(docker ps -f name="imagewolf." --format {{.ID}})# Configuration for the notification endpoint
export REGISTRY_NOTIFICATIONS_ENDPOINTS=$(cat <