k8s, deployment

控制循环(control loop)

go 复制代码
for {
  实际状态 := 获取集群中对象X的实际状态(Actual State)
  期望状态 := 获取集群中对象X的期望状态(Desired State)
  if 实际状态 == 期望状态{
    什么都不做
  } else {
    执行编排动作,将实际状态调整为期望状态
  }
}

"用一种对象管理另一种对象"的"艺术"。

Deployment看似简单,但实际上,它实现了Kubernetes项目中一个非常重要的功能:Pod的"水平扩展/收缩"(horizontal scaling out/in)。这个功能,是从PaaS时代开始,一个平台级项目就必须具备的编排能力。

Deployment就需要遵循一种叫作"滚动更新"(rolling update)的方式,来升级现有的容器。依赖的是Kubernetes项目中的一个非常重要的概念(API对象):ReplicaSet。

Deployment控制器实际操纵的,正是这样的ReplicaSet对象,而不是Pod对象。

查看滚动升级:

Deployment的控制器,实际上控制的是ReplicaSet的数目,以及每个ReplicaSet的属性。

一个应用的版本,对应的正是一个ReplicaSet;这个版本应用的Pod数量,则由ReplicaSet通过它自己的控制器(ReplicaSet Controller)来保证。

kubectl rollout history命令,查看每次Deployment变更对应的版本
kubectl rollout history deployment/nginx-deployment --revision=2
kubectl rollout undo deployment/nginx-deployment --to-revision=2

我们对Deployment进行的每一次更新操作,都会生成一个新的ReplicaSet对象,是不是有些多余,甚至浪费资源呢?
kubectl rollout pause deployment/nginx-deployment

Deployment正处于"暂停"状态,所以我们对Deployment的所有修改,都不会触发新的"滚动更新",也不会创建新的ReplicaSet。
kubectl rollout resume deployment/nginx-deployment

kubectl rollout resume指令执行之前,在kubectl rollout pause指令之后的这段时间里,我们对Deployment进行的所有修改,最后只会触发一次"滚动更新"。

相关推荐
AllData公司负责人5 分钟前
亲测丝滑,体验跃迁|AllData通过集成开源项目Cube-Studio,降低机器学习落地门槛
java·大数据·数据库·人工智能·机器学习·开源·cube-studio
蜀道山老天师6 分钟前
Docker 进阶:数据持久化与容器网络互联(数据卷、挂载目录、端口映射、自定义网络)
运维·网络·docker·云原生·容器
IT策士11 分钟前
Docker 从 0 到 1 再到 Kubernetes 实战:第6篇 容器生命周期管理
docker·容器·kubernetes
zxd02031126 分钟前
DevOps + CI/CD:从理念到 Jenkins 实战落地
java·开发语言
qq_白羊座27 分钟前
GitLab CI + Jenkins 双流水线模式Jenkins 端实现
java·开发语言
填满你的记忆29 分钟前
《RAG 完整工作流程详解》
java·ai·agent·rag
Kurisu57530 分钟前
深度解析:Go 语言 GMP 调度器模型与内核线程探测
java·数据库·golang
架构源启30 分钟前
Spring AI进阶系列(11) Spring AI Multi-Agent 协作系统:辩论、投票与共识机制实战
java·人工智能·spring
一条泥憨鱼35 分钟前
深入理解Java反射(超详细)
java·开发语言·spring·mybatis·反射
IT策士38 分钟前
Docker 从 0 到 1 再到 Kubernetes 实战:第1篇 为什么要从 Docker 学到 Kubernetes?系列导读与环境准备
docker·容器·kubernetes