问题描述
我有一个包含 Dockerfile 和 github 触发器的存储库,每次将提交推送到分支时都会触发。每当我提交任何更改时,它都会创建一个带有标签的新 docker 映像:分支名称和 git hash(是的,两者都是)并将其推送到注册表。在我的工作负载中,图像被描述为 image:branch_name。如果我手动重新部署,它会拉取最新的图像并且一切正常。但是当我和詹金斯一起做的时候问题就出现了。因为,在deployment.yml 中,image 是imagename:branch_name,它一直是静态的。
现在,我已经配置了一个 jenkins 作业来执行 kubectl apply -f deployment.yml
。但是,这不会每次都提取最新的图像,因为 yml 文件没有更改(图像和分支名称相同)。如何让 Kubernetes 每次都拉取最新的镜像?
我的一个想法是将 githash 传递给 deployment.yml,以便将更改推送到文件中,触发部署。我怎样才能做到这一点?
PS:我已经知道 kubectl rolling-restart
和 kubectl apply
。我想使用上述方法。有什么办法吗?
解决方法
您可以更新部署的映像,它会自动触发发布。 当你用 git hash 标记图像时 - 这很好 - 然后你可以在构建结束时运行这样的东西:
kubectl set image deployment/my-deployment container_name=myimage:buildhash
您可以将 imagePullPolcy
设置为 Always
,它总是会拉取最新的图像,或者如果这还不够,那么总有 Flux 可以监视您的存储库并根据您的规则更新您的清单指定(最高数字、语义版本控制规则等)。
我终于用 kubectl 补丁做到了
kubectl patch deployment <deployment name> -p "{\"spec\":{\"template\":{\"metadata\":{\"labels\":{\"build\":\"${BUILD_ID}\"}}}}}}"