Docker image的tag是不稳定的,这句话的意思是 就算tag不变,其所代表的image并非一成不变
,例如 openjdk:8
在去年代表jdk 8u161今年则代表jdk 8u191。就算你使用 openjdk:8u181
也不能保证这个image是不变的,为什么这么说?
一个Docker image大致是由4部分组成的:
FROM docker-entrypoint.sh
就算软件不发生变化,另外3个也是有可能发生变化的,而构建的新image的tag依然是 openjdk:8u181
。而且要注意到一般采用的是软件的版本号作为tag,而不是commit、构建日期作为tag。如果你是Java程序员,可以类比docker image tag为maven的 SNAPSHOT
。
那这意味着什么?
和Maven的版本定义一样,你的软件应该分为两种:
对于stable版,你应该定期对其构建image。比如你有版本1.0、1.1、1.2,那你应该定期从软件仓库中下载这三个版本的构建物,然后对为它们构建image。以Maven举例,定期从Maven仓库下载它们的Jar,然后为它们构建image。记得确保 docker build
添加了 --pull
选项。
对于snapshot版,你应该将构建image的过程融入到软件的构建过程中。以Maven为例,使用 spotify-dockerfile-plugin
, mvn clean install dockerfile:build dockerfile:push
。
不论是stable版还是snapshot版,都应该利用CI/CD工具(如Jenkins)将image构建工作自动化。