This document describes how to release a new set of Docker images for OpenZipkin. The images are built automatically on quay.io and mirrored to Docker Hub.
Each release is tagged with a semantic version number like 1.1.4
. The Docker tags 1.4
and 1
point to the latest
tag under them, to let users choose the level of version pinning they prefer.
-
Update zipkin-ui/Dockerfile with the latest release
Commit the latest release of https://github.com/openzipkin/zipkin-ui since version numbers aren't aligned.
-
Create, push a tag
release-1.1.4
This triggers a Travis job on openzipkin/docker-zipkin that just takes care of everything, except for:
-
Test the new images
Locally change
docker-compose.yml
to use the newly built versions (the tag will be something like1.1.4
), executedocker-compose up
, and verify that all is well with the world. TBD: How exactly do we do that? -
Commit, push
docker-compose.yml
-
There is no step four
Congratulations, the intersection of the sets (OpenZipkin users) and (Docker users) can now enjoy the latest and greatest Zipkin release!
-
Get a Quay.io OAuth 2 token
Go to https://quay.io/organization/openzipkin/application/QREQHLDQGW2LI4OGGD6C?tab=gen-token and generate a token with "Read/Write to any accessible repositories" permissions. Export this token to be used by the release script:
export QUAYIO_OAUTH2_TOKEN='...'
This token will be used to sync up the Docker tags
1
and1.4
when you release1.1.4
. -
Activate your Docker environment
Make sure you have
$DOCKER_HOST
and friends set. The easiest way to check this is to rundocker version
, which will print the version of your Docker daemon as well as your server. For many people,eval $(docker-machine env dev)
or some slight variation will take care of this. -
Log in to Docker Hub
Make sure your Docker client configuration has your credentials to hub.docker.com. The easiest way to get this right is to issue the command
docker login
and enter your credentials.This will be used when syncing the built images from Quay.io to Docker Hub.
-
Run
release.sh $RELEASE_TAG
RELEASE_TAG
should be a semantic version number prefixed byrelease-
, likerelease-1.1.4
. Go grab a coffee.The script will create a Git tag
1.1.4
that triggers the builds. It waits for those, then syncs up the Docker tags1
and1.4
to the Docker tag1.1.4
created by these builds. Finally it syncs the built images to Docker Hub. -
Test the new images
Locally change
docker-compose.yml
to use the newly built versions, saydocker-compose up
, and verify that all is well with the world. TBD: How exactly do we do that? -
Commit, push
docker-compose.yml
-
Done!
Congratulations, you're done!
Assume we're releasing 1.1.4
.
- The ENV var
ZIPKIN_VERSION
in anyDockerfile
s that reference it is updated, committed and pushed - The tag
1.1.4
is created and pushed. The quay.io repositories for images (zipkin-cassandra
,zipkin-collector
,zipkin-kafka
, andzipkin
) are configured to trigger a build on tags that look match\d+\.\d+\.\d+
. - The script waits for the build of each build to start (timeout 5 minutes) and finish (no timeout) using the quay.io API to poll for them. It does this one by one for each build, so usually there's only any waiting for the first image; the rest are also about done by the time that's finished.
- The tags
1
,1.4
,1.1.4
for the services are synced to Docker Hub by pulling them from quay.io using thedocker
CLI and pushing them to Docker Hub. - A friendly message is printed to remind the release manager (HAH! Such words.) about manually testing the release
and updating the tags in
docker-compose.yml
. This last part could definitely use more automation.