如何使用Kubectl 滚动重启应用
Kubernetes 中的 Pod 通常应该是"Running"状态,然而有时候我们需要针对正在运行的Pod调度到其它的节点或是基于其它特殊的原因,将正常运行的Pod进行重启。Pod的重启方式也有不少,比如常见删除正在运行的Pod让其创建新的Pod实例(单个Pod无法直接使用该方式)。以下罗列出几种常见的方式仅供备忘:
方法1:滚动重启方法[推荐]
自 Kubernetes 1.15 版本就开始支持滚动重启部署。这是 Kubernetes 中最快的重启机制,因为它是新增的。下面给出的命令会一个一个地关闭并重新启动部署中的每个Pod。
kubectl rollout restart deployment nginx-deploy
提示:由于大多数容器仍在运行,因此整个过程是纵享丝滑--无感知的。
方法2:环境变量方法
这种方式就是给运行的容器分配一个新的环境变量,来强制 pod 重新启动。例如: 增加一个容器部署日期(实际可能未使用到该变量)
kubectl set env deployment nginx-deploy DEPLOY_DATE="$(date)"
提示:在上面的场景中,使用了
set env
修改了环境变量,deployment [deployment name] 选择了你的deployment,DEPLOY DATE="$(date)" 修改了deployment date 并导致pod 更新。这种方式也是无感知的。
方法3:副本扩/缩容
当副本数量设置为0时,Kubernetes 会消除它不再需要的副本。设置大于0后,Kubernetes 会生成新的副本。
kubectl scale --replicas=0 deployment nginx-deploy
kubectl scale --replicas=N deployment nginx-deploy
以上方式会中断业务,我们也可以使用不中断业务的方式来重启应用。比如记录当前的Pod副本数量,使用scale --replicas
命令来分配一个大于当前的副本数值的值,使用kubectl delete pod
方式删除旧Pod,最后将使用scale --replicas
还原成正常的副本数量。
提示:不建议使用这种方式来重启应用。
结论
Kubernetes 是一个非常牛X的编排系统,然而只要是系统,就一定会出现问题。当出现问题时,可以利用上述3种方式快速安全地让您的应用程序恢复并运行,而不会影响用户体验。