您还没有提到您的部署策略。但是我在k8s部署中看到的一个普遍问题是,如果应用程序无法启动,它将无限重启。因此,在检测到部署失败状态后,您可能必须明确地指定kubectl delete deploy/******
。 (探针也有failureThreshold
,但我还没有尝试)。
案例重新创建:
您可以使用progressDeadlineSeconds
和readinessProbe
组合。假设您的应用程序需要60秒才能启动/启动。你需要配置progressDeadlineSeconds
60秒多一点,只是在更安全的一面。现在,运行kubectl apply -f my-deploy.yaml
后,运行kubectl rollout status deploy/my-deployment
命令。对我来说,它看起来像这样:
12:03:37 kubectl apply -f deploy.yaml
12:03:38 deployment "my-deployment" configured
12:04:18 kubectl rollout status deploy/my-deployment
12:04:18 Waiting for rollout to finish: 0 of 1 updated replicas are available (minimum required: 1)...
12:04:44 deployment "my-deployment" successfully rolled out
一旦执行rollout
命令,kubectl将保持等到它有一些答案。此外,它返回一个适当的退出代码echo $?
- 您可以通过编程方式检查并删除部署。
案例rollingUpdate:
如果你有多个副本,那么上面提到的技巧应该工作。 如果您只有一个副本,请使用maxUnavailable: 0
和maxSurge: 1
以及上述配置。
“kubectl部署状态deploy/my-deployment”将检查最新部署。是否可以选择刚刚触发的部署? – yogiginger
@Amrit Bera获得展示状态退出代码似乎不是一个可扩展的解决方案,因为它只会在成功部署最新部署并完全移除旧部署时才会成功推出。因此,很难获得正确的超时值这个。你有什么更好的解决方案?我现在面临这个问题。 –