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

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

1、更新Deployment配置:
  • 当需要对应程序进行升级时,通常会更新Deploymen的yaml配置文件,可以更新的内容包括但不限于:
    • 容器镜像版本(v1.0–升级–>v2.0)
    • 应用配置(环境变量、命令参数)
    • 资源请求与限制
    • 更新策略和其他元数据
2、选择升级策略:
  • 默认情况,Deployment使用滚动升级(Rolling Update)策略
  • 滚动升级会在保持整体服务可用的前提下逐步替换旧的Pod,即首先创建新的Pod实例运行新版本运行,然后删除旧版本的Pod实例
  • 另一种策略是Recreate策略,它会先删除所有现有的Pod,然后再创建全部新的Pod
3、实施滚动升级:
  • 在滚动升级过程中:
    • Deployment控制器根据新的Pod模板创建一个新的ReplicaSet
    • 新的ReplicaSer开始创建并启动指定数量的新Pod,同时确保任何时候集群中至少有一部分旧的Pod仍在提供服务(可以通过配置.spec.strategy.rollingUpdate.maxUnavailable来控制最大不可用Pod数量)
    • 当新Pod变成Ready状态且通过就绪探针(Readiness Probe)验证后,才会继续替换下一个旧的Pod
    • 这个过程会持续进行,直到所有旧Pod都被新Pod替换完毕
4、监控和确认升级:
  • 在升级过程中,可以通过kubectl或kubernetes Dashboard监控Deployment的状态以及Pod的健康状况
  • 确认所有新Pod都成功并且应用程序正常响应后,升级过程成功
5、回滚机制:
  • 如果在升级过程中发现问题,可以立即执行回滚操作回到上一个稳定版本中
  • kubernetes自动维护着每个Deployment的历史记录,允许用户轻松的基于修订历史(revision history)回滚到之前任何一个版本

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值