在K8S中,deploy升级过程包括什么?

在Kubernetes (K8S) 中,Deployment的升级过程主要包括以下几个步骤:

  1. 更新Deployment配置

    • 当需要对应用程序进行升级时,通常会更新Deployment的YAML配置文件,可以更改的内容包括但不限于:
      • 容器镜像版本(从v1.0升级到v2.0)
      • 应用配置(环境变量、命令参数等)
      • 资源请求与限制
      • 更新策略和其他元数据
  2. 选择升级策略

    • 默认情况下,Deployment使用滚动升级(Rolling Update)策略。
    • 滚动升级会在保持整体服务可用的前提下逐步替换旧Pod,即首先创建新的Pod实例运行新版本应用,然后删除旧版本Pod实例。
    • 另一种策略是Recreate策略,它会先删除所有现有的Pod,然后再创建全部新的Pod。
  3. 实施滚动升级

    • 在滚动升级过程中:
      • Deployment控制器根据新的Pod模板创建一个新的ReplicaSet。
      • 新的ReplicaSet开始创建并启动指定数量的新Pod,同时确保任何时候集群中至少有一部分旧Pod仍在提供服务(可以通过设置.spec.strategy.rollingUpdate.maxUnavailable来控制最大不可用Pod数量)。
      • 当新Pod变为Ready状态且通过就绪探针验证后,才会继续替换下一个旧Pod。
      • 这个过程会持续进行,直到所有旧Pod都被新Pod替换完毕。
  4. 监控和确认升级

    • 在升级过程中,可以通过kubectl或Kubernetes Dashboard监控Deployment的状态以及Pod的健康状况。
    • 确认所有新Pod都成功启动并且应用程序正常响应后,升级过程完成。
  5. 回滚机制

    • 如果在升级过程中发现问题,可以立即执行回滚操作回到上一个已知稳定版本。
    • Kubernetes自动维护着每个Deployment的历史记录,允许用户轻松地基于修订历史(revision history)回滚到之前任何一个版本。

综上所述,整个升级流程旨在实现最小的服务中断和最大程度的可恢复性。

相关推荐
恼书:-(空寄6 小时前
K8s Ingress 七层网关 + 灰度发布 + HTTPS 实战
容器·kubernetes
不是书本的小明6 小时前
ACK+ESS实现K8s节点自动扩缩容
容器·kubernetes
恼书:-(空寄7 小时前
Docker Swarm + K8s 集群部署完整指南
docker·容器·kubernetes
yuanlaile8 小时前
Linux Docker、Swarm、K8s分布式部署全集解析
linux·docker·kubernetes·k8s实战
观测云10 小时前
Python 应用实现 APM 自动注入(Kubernetes 篇)
开发语言·python·kubernetes
A-刘晨阳11 小时前
K8s之StatefulSet控制器
运维·云原生·容器·kubernetes·statefulset
馨谙1 天前
OpenEBS + PV/PVC 解析:命令、文件、作用、后续用法
云原生·容器·kubernetes
亚马逊云开发者1 天前
告别手动部署:在 Amazon EKS 上用 CodePipeline + Argo CD 搭建 GitOps CI/CD
elasticsearch·ci/cd·kubernetes
姚不倒2 天前
深入浅出 Kubernetes CRD、Operator 与 CR
云原生·容器·kubernetes
阿干tkl2 天前
openEuler 系统 Kubernetes + Harbor 学习测试环境详细部署指南
容器·kubernetes