Hands-On Kubernetes on Windows
上QQ阅读APP看书,第一时间看更新

Semantic versioning 

In order to efficiently manage the versioning and tagging of Docker images, you can use Semantic Versioning (Semver) as a general strategy. This versioning scheme is widely adopted among image distributors and helps consumers understand how your image evolves.

Generally, Semver suggests the scheme of using three numbers  major, minor, and patch  separated with dots, <major>.<minor>.<patch>, where each number is incremented as needed. As an example, 2.1.5 means that the major version of the image is 2, the minor version is 1, and the patch version is currently 5. The meaning of these release numbers and incrementation rules are similar to what you would expect for versioning non-containerized applications:

  • Major: Increment if you are introducing features that break compatibility or introduce other breaking changes.
  • Minor: Increment if you are introducing features that are fully compatible with previous releases. Consumers do not need to upgrade usages of your application.
  • Patch: Increment if you are publishing bug fixes or patches. 
More details regarding Semver as a general concept can be found here:  https://semver.org/.

The best practices for using Semver when building/pushing Docker images can be summarized as follows:

  • When building a new version of your image, always create a new patch tag (for example, 2.1.5).
  • Always overwrite existing major and minor tags (for example, 2 and 2.1).
  • Never overwrite patch tags. This ensures that image consumers who would like to use a specific version of your application can be sure that it does not change over time.
  • Always overwrite the existing latest tag.

The following set of commands shows an example of building and tagging a new version of the applicationimage Docker image:

# New build a new version of image and push latest tag
docker build -t applicationimage:latest .
docker push applicationimage:latest

# New major tag
docker tag applicationimage:latest applicationimage:2
docker push applicationimage:2

# New minor tag
docker tag applicationimage:latest registry:2.1
docker push applicationimage:2.1

# New patch tag
docker tag applicationimage:latest applicationimage:2.1.5
docker push applicationimage:2.1.5

You may also introduce additional tags that add correlation to your build system IDs or git commit SHA-1 hash, which was used for the image build.