0

我有一个包含 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-restartkubectl apply。我想使用上述方法。有什么办法吗?

4

3 回答 3

0

您可以设置imagePullPolcyAlways,它总是会拉取最新的图像,或者如果这还不够,总有Flux可以监视您的存储库并根据您指定的规则(最高编号、语义版本控制规则等)更新您的清单。

于 2021-04-04T01:53:10.103 回答
0

您可以更新部署的映像,它会自动触发部署。当你用 git 哈希标记图像时——这很好——然后你可以在构建结束时运行这样的东西:

kubectl set image deployment/my-deployment container_name=myimage:buildhash

于 2021-03-05T18:56:49.420 回答
0

我终于用 kubectl 补丁做到了

kubectl patch deployment <deployment name> -p "{\"spec\":{\"template\":{\"metadata\":{\"labels\":{\"build\":\"${BUILD_ID}\"}}}}}}"
于 2021-04-19T00:08:54.947 回答