k8s deployment

deployment

假设 pod 一开始使用v1版本的镜像运行第一个版本的应用。然后开发了一个新版本的应用打包成镜像,并将其推送到镜像仓库,标记为v2,接下来想用这个新版本替换所有的 pod。由于 pod 在创建之后,不允许直接修改镜像, 只能通过删除原有 pod 并使用新的镜像创建新的 pod替换。

有两种办法更新所有 pod:

  1. 直接删除所有现有的 pod,然后创建新的 pod。
  2. 先创建新的 pod,等待运行成功之后,再删除旧的 pod。

第一种方法会造成服务在一定时间内的不可用。第二种方法需要同时支持两个版本同时提供对外服务。

滚动升级

执行滚动升级操作来逐步替代原有的 pod,而不是同时创建所有新的 pod 并一并删除所有旧的 pod。可以通过逐步对旧版本的 ReplicationController 进行缩容并对新版本的进行扩容, 来实现上述操作。在这个过程中,服务的 pod 选择器同时包含新旧两个版本的 pod, 因此它将请求切换到这两组 pod。

deployment 和 replicaset

Deployment 不能直接管理 pod,而是创建了 ReplicaSet 来管理 pod。ReplicaSet的名称中也包含了其 pod 模板的哈希值。

相关推荐
虚伪的空想家17 小时前
云镜像,虚拟机镜像怎么转换成容器镜像
服务器·docker·容器·k8s·镜像·云镜像·虚机
人工智能训练18 小时前
Linux 系统核心快捷键表(可打印版)
linux·运维·服务器·人工智能·ubuntu·容器·openeuler
x***133919 小时前
使用Docker快速搭建Redis主从复制
redis·docker·容器
sanduo11220 小时前
docker 构建编排过程中常见问题
运维·docker·容器
K***65891 天前
冯诺依曼架构和哈佛架构的主要区别?
微服务·云原生·架构
eddy-原1 天前
Docker与DevOps实战训练:从容器管理到全链路项目部署
docker·容器·devops
Empty_7771 天前
K8S-Pod资源对象
java·容器·kubernetes
谷隐凡二1 天前
Go语言实现Kubernetes主从架构模拟系统
架构·golang·kubernetes
人工智能训练1 天前
Windows系统Docker中Xinference 集群无法启动的解决方法
linux·运维·服务器·windows·docker·容器·xinference
java_logo1 天前
Prometheus Docker 容器化部署指南
运维·人工智能·docker·容器·prometheus·ai编程