稳定与非稳定版本软件的Docker Image构建策略

原文

Image tag是不稳定的

Docker image的tag是不稳定的,这句话的意思是就算tag不变,其所代表的image并非一成不变,例如openjdk:8在去年代表jdk 8u161今年则代表jdk 8u191。就算你使用openjdk:8u181也不能保证这个image是不变的,为什么这么说?

一个Docker image大致是由4部分组成的:

  1. 其依赖的基础镜像,由Dockerfile的FROM指令所指定
  2. 其所包含的软件,在这个例子里就是 openjdk 8u181
  3. Dockerfile的其他脚本
  4. 启动入口,比如docker-entrypoint.sh

就算软件不发生变化,另外3个也是有可能发生变化的,而构建的新image的tag依然是openjdk:8u181。而且要注意到一般采用的是软件的版本号作为tag,而不是commit、构建日期作为tag。如果你是Java程序员,可以类比docker image tag为maven的SNAPSHOT

那这意味着什么?

  • 从docker image使用方角度,每次启动之前都需要pull一下,确保使用了新的image
  • 从docker image提供方角度,就算你的软件版本已经冻结,你仍然需要定期构建image并发布仓库上

针对稳定与非稳定版本的构建策略

和Maven的版本定义一样,你的软件应该分为两种:

  • stable版,即一旦发布其版本号对应的代码不会再做修改
  • snapshot版,又称nightly-build版,即该版本号对应的代码是不稳定的

对于stable版,你应该定期对其构建image。比如你有版本1.0、1.1、1.2,那你应该定期从软件仓库中下载这三个版本的构建物,然后对为它们构建image。以Maven举例,定期从Maven仓库下载它们的Jar,然后为它们构建image。记得确保docker build添加了--pull选项。

对于snapshot版,你应该将构建image的过程融入到软件的构建过程中。以Maven为例,使用spotify-dockerfile-pluginmvn clean install dockerfile:build dockerfile:push

不论是stable版还是snapshot版,都应该利用CI/CD工具(如Jenkins)将image构建工作自动化。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值