常见重启 Pod 的五种方法
1. 直接删除 Pod
原理:删除 Pod 后,控制器(如 Deployment、StatefulSet)会自动创建新 Pod。
复制
kubectl delete pod <pod-name> -n <namespace>
kubectl deploy pod nginx-f49c8d898-2jt8t -n prod1.2.3.
注意:可能导致短暂服务中断(若单副本,多副本不影响)。
原理:通过更新策略逐步替换旧 Pod,确保服务可用性。
复制
kubectl rollout restart deployment/<deployment-name> -n <namespace>1.
注意:不适用于 DaemonSet(需其他方法)。
3. 调整副本数触发重建原理:通过缩容到 0 再扩容,强制重建 Pod。
复制
kubectl scale deployment/<deployment-name> --replicas=0 -n <namespace> \
&& kubectl scale deployment/<deployment-name> --replicas=2 -n <namespace>1.2.
注意:服务会中断,生产环境慎用。
4. 编辑配置并应用原理:修改 Pod 模板(如环境变量),触发更新。
复制
kubectl edit deployment/<deployment-name> -n <namespace>1.
修改后保存退出,K8s 自动应用
注意:任何模板字段变更都会触发滚动重启。
5. 容器内执行重启命令原理:进入容器执行进程重启(需权限)。 命令:
复制
kubectl exec <pod-name> -n <namespace> -- /bin/sh -c "kill 1"1.
注意:依赖容器内 PID 1 进程处理信号,可能不生效。
6. 五种方法对比方法
适用控制器
服务中断风险
推荐场景
直接删除 Pod
所有
高(单副本)
测试、调试
滚动重启
Deployment, StatefulSet
低
生产环境
调整副本数
所有
高
紧急情况
修改配置
支持更新的控制器
低
配置变更触发重启
容器内重启
单个 Pod
不定
调试
根据业务需求选择合适方法,生产环境优先使用滚动重启或配置更新以保证可用性。
阅读剩余
THE END