【kubernetes】kubernetes中的Deployment使用

news2024/11/24 11:27:36

1 Why need Deployment?

K8S中Pod是用户管理工作负载的基本单位,Pod通常通过Service进行暴露,因此,通常需要管理一组Pod,RC和RS主要就实现了一组Pod的管理工作,其中,RC和RS的区别在于,RS提供更加高级的选择器(RS支持基于集合的选择符)。

在实际生产环境中,应用在初次部署完成后,当测试正常才会对外提供服务,之后就都是升级操作,而升级过程中,意味着删除老的Pod,并创建新的Pod。对于RS而言,如果需要升级Pod的镜像,可以使用kubectl edit修改RS中的Pod的镜像,或者直接修改RS的资源文件,然后执行kubectl apply,但是,这样做的话,会使得服务在短期内的不可用。虽然Service可以保证请求只路由到ready的Pod,并且RS会按照一定的策略删除老的Pod,然后再创建新的Pod,但是,在删除和创建的过程中可能无法保证服务的正常:无法保证永远有Pod在ready状态;无法保证有一定数量的Pod在处理请求。

为了解决服务更新的问题,K8S在RS的基础上提供了Deployment,它最大的特点是提供了滚动升级的能力,并且可以控制升级的速率,使得升级过程中可以正常提供服务,因此,通常都是使用Deployment,而不是RC或者RS。

2 Problem of ReplicaSet

设想一下,在只有RS的情况下,如何进行滚动升级,当然,在设计滚动升级流程之前必须要明确几个目标:

  • 升级过程中有固定数量的Pod提供服务
  • 为了保证服务不发生抖动,给定灰度的时间,可以减缓升级的速率
  • 如果升级过程中发现请求处理异常可以及时回退

为了实现这些目标,在只有RS的情况下,你可能会这么做(假设RS的replicas为3):

  • 用新的Pod的template创建新的RS,然后在RS的selector中新增标签,假设为A,并且RS的replicas设置为0
  • 在原来的RS的selector和Pod中都加一个标签,假设为B,这样的话,这些Pod就只被老的RS管理,并通过Service对外暴露
  • 将老的RS的replicas减1,新的RS的replicas加1,现在,old_replicas=2,new_replicas=1,并且由于A、B的存在,新老RS只管理各自的Pod,互不干扰,而这些Pod都可以被Service选择
  • 此时,Service的Pod同时有新老两个版本,这时候就可以通过监控查看成功率,如果没有问题,等待一段时间(相当于灰度时间)
  • 确认新的Pod没有问题,继续升级:老的RS的replicas继续减1,新的RS的replicas继续加1,现在old_replicas=1,new_replicas=2,继续关注监控指标
  • 继续升级:old_replicas=0,new_replicas=3,此时,所有的Pod都升级到了新版本

升级过程中总是有3个Pod提供服务,如果升级过程发现异常,可以直接修改old_replicas进行回退,同时,为了持续观察新的Pod的情况,在新的Pod创建完成后,不是立刻就对外提供服务,而是会等待一段时间,用于观察请求成功率,从而决定是否继续进行升级。

上面的过程比较复杂,而且灰度期间如果有问题,需要人工回滚,为了解决滚动更新的问题,K8S提供了Deployment,相比于ReplicaSet,它最大的优势就是滚动更新。

3 What is Deployment

从基础字段上看Deployment跟ReplicaSet没有任何区别,都是在Pod的基础上增加replicas字段,保证副本的数量,Deployment的主要功能也是保证副本的数量。但是,为了保证服务的可用性,相比于ReplicaSet,Deployment提供了滚动更新的能力。

Deployment提供的滚动更新跟上面的人工更新过程类似,也是创建额外的RS,然后修改新老RS的replicas值,然后再添加一些策略,例如,是全部一起更新,还是一个接一个的更新。

4 How to use Deployment

由于Deployment要创建多个Pod的副本,因此,Deployment中十分重要的字段就是PodTemplate和副本数:deployment.spec.template、deployment.spec.replicas。

剩下的字段基本都跟升级相关:

  • deployment.spec.progressDeadlineSeconds:当Deployment在一段时间内还没有升级成功,则会在deployment.status.conditions中的Progressing设置为False
  • deployment.spec.revisionHistoryLimit:保存用于回滚的历史版本数量,默认是10
  • deployment.spec.strategy:升级策略,这里有两种策略:Recreate、RollingUpdate。当deployment.spec.strategy.typeRollingUpdate时,表示滚动更新,并且可以设置deployment.spec.strategy.rollingUpdate.maxSurge(最大峰值,升级过程中可以创建出的超过预期pod数量的pod个数)和deployment.spec.strategy.rollingUpdate.maxUnavailable(最大不可用,升级过程中不可用的pod的数量,可以使用数字和百分比)。当deployment.spec.strategy.typeRecreate时,会干掉所有pod,当所有pod被干掉后,再创建新的pod。
kubectl create deployment --image=nginx my-nginx

上述语句创建了一个nginx的deployment,副本数和升级策略都是用的默认值:replcas=1,maxSurge=25%,maxUnavailable=25%。

4.1 Deployment相关资源和字段解释
kubectl get deploy my-nginx

上述命令可与查看该deployment,输出的结果中有三个重要字段:

  • READY:就绪的pod数量,
  • UP-TO-DATE:pod的定义与deployment中的Pod模板相同的pod的个数
  • AVAILABLE:可用的pod数量
4.2 Deployment的升级

Deployment通常通过更新镜像进行升级:

kubectl set image deploy my-nginx nginx=nginx:1.9.1
kubectl annotate deploy my-nginx kubernetes.io/change-cause="set nginx to 1.9.1"

上述语句先更新my-nginx这个Deployment的nginx容器的镜像,再使用annotate设置变更的原因,最后可以使用kubectl rollout status deploy my-nginx查看更新状态。

执行kubectl describe deploy my-nginx可以查看更新过程:

请添加图片描述

同时可以查看历史版本:

请添加图片描述

这里的CHANGE-CAUSE就是上面设置的annotate,另外,这里需要注意的是,这里只会保存不重复的版本,如果用两个镜像交替更新,这里只会保存两个版本。

4.3 Deployment的回滚

当升级过程中出现问题,如果是升级过程就卡主了,例如,pod没起来,或者拉取镜像失败,老的pod不会被干掉,此时也不会有啥问题。如果是程序的bug造成的问题,通过监控或者其他方式验证发现了问题,可以对Deployment进行回滚。

kubectl rollout undo deploy my-nginx

此时,deployment会回到上个版本,并且在rollout history中可以看到之前的版本换到了最新版本,版本号加1:

请添加图片描述

当然,也可以回滚到指定版本:

kubectl rollout undo deploy my-nginx --to-revision=3
4.4 Deployment的手动缩放

当pod数量不够或者过多时,可以手动修改Deployment的replicas配置:

kubectl scale deploy my-nginx --replicas=3

收到将Deployment的副本数设置为3。

5 小结

Deployment作为k8s中无状态部署的最常用的资源,所有的业务逻辑层的高可用和负载均衡都会用它来部署。当Deployment资源已经创建后,可以通过kubectl set imagekubectl scale更新镜像和副本数,还能够使用kubectl rollout undo进行回滚,同时,可以使用kubectl rollout history查看历史版本。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1054098.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

C++ - 开散列的拉链法(哈希桶) 介绍 和 实现

前言 之前我们介绍了,闭散列 的 开放地址法实现的 哈希表:C - 开放地址法的哈希介绍 - 哈希表的仿函数例子_chihiro1122的博客-CSDN博客 但是 闭散列 的 开放地址法 虽然是哈希表实现的一种,但是这种方式实现的哈希表,有一个很大的…

使用sqlmap获取数据步骤

文章目录 1.使用sqlmap获取所有数据库2.使用sqlmap获取当前连接数据库3.使用sqlmap获取当前数据库下所有表名4.使用sqlmap获取当前数据库下某个表下所有列名5.使用sqlmap获取当前数据库下某个表下指定字段的数据6.测试当前用户是否是管理员7.使用burpsqlmap批量检测8.脱库命令9…

【接口技术】总线课堂习题

1:CPU在执行OUT DX, AL指令时,()寄存器的内容送到地址总线上 A,DL B,DX C,AX D,DL 解答:B out指令是把AL的数据输出到DX的端口,因此AL寄存器的内容送到…

多线程学习笔记(一)

文章目录 1 线程基础知识复习2 CompletableFuture1、Future和Callable接口2、FutureTask3、对Future的改进4、案例精讲——电商5、常用方法6、CompetableFutureWithThreadPool【重要】 3 锁1、乐观锁和悲观锁2、synchronized 8锁案例3、公平锁和非公平锁4、可重入锁5、死锁及排…

正点原子嵌入式linux驱动开发——TF-A初探

上一篇笔记中,正点原子的文档简单讲解了一下什么是TF-A,并且也学习了如何编译TF-A。但是TF-A是如何运行的,它的一个运行流程并未涉及。TF-A的详细运行过程是很复杂的,涉及到很多ARM处理器底层知识,所以这一篇笔记的内容…

剖析华为云Astro Platform技术价值与使用体验

面对企业IT专业人员紧缺的挑战,华为云Astro低代码平台提供创新解决方案。让非编程专业人士能快速构建、部署应用,缓解开发资源压力,并高度整合技术架构,强化项目沟通协作。使每个参与其中的角色都找到自己的位置,携手全…

初级篇—第三章多表查询

文章目录 为什么需要多表查询一个案例引发的多表连接初代查询笛卡尔积(或交叉连接)的理解 多表查询分类等值连接 vs 非等值连接自连接 vs 非自连接内连接VS外连接 SQL99语法实现多表查询内连接的实现外连接的实现左外连接右外连接满外连接 UNION的使用7种…

leetCode 455.分发饼干 贪心算法

455. 分发饼干 - 力扣(LeetCode) 假设你是一位很棒的家长,想要给你的孩子们一些小饼干。但是,每个孩子最多只能给一块饼干。 对每个孩子 i,都有一个胃口值 g[i],这是能让孩子们满足胃口的饼干的最小尺寸&…

全网最全Python系列教程(非常详细)---集合讲解(学Python入门必收藏)

🧡🧡🧡这篇是关于Python中集合的讲解,涉及到以下内容,欢迎点赞和收藏,你点赞和收藏是我更新的动力🧡🧡🧡 1、集合是什么? 2、集合应该怎么去定义&#xff1f…

从零手搓一个【消息队列】实现数据的硬盘管理和内存管理(线程安全)

文章目录 一、硬盘管理1, 创建 DiskDataCenter 类2, init() 初始化3, 封装交换机4, 封装队列5, 关于绑定6, 关于消息 二、内存管理1, 数据结构的设计2, 创建 MemoryDataCenter 类3, 关于交换机4, 关于队列5, 关于绑定6, 关于消息7, 恢复数据 三、小结 创建 Spring Boot 项目, S…

Xcode 超简单实用小秘技让撸码进入新境界

概览 Xcode 是开发  应用不可或缺的王牌主力军,虽然 Xcode 中一些常用使用姿势想必大家都已驾轻就熟,但其中仍有一些隐藏宝藏小技巧不为人知。 充分挖掘它们可以极大加速和方便秃头码农们日常的撸码行为。 一般的,它们分为两类&#xff…

机器人制作开源方案 | 四轴飞行器

1. 概述 基于探索者搭建的模块化四轴飞行器研究平台,采用独特的设计方式,可实现在室内完成对四轴飞行器、无人机等运动控制的原理研究,以及学习飞行控制的原理知识。 2. 组装 请按照下图进行机架的组装。 整体图 请解压文末资料中的 /软件/Mi…

前端JavaScript入门到精通,javascript核心进阶ES6语法、API、js高级等基础知识和实战 —— Web APIs(一)

思维导图 学习目标 变量声明 一、Web API 基本认知 作用和分类 什么是DOM DOM树 DOM对象 二、获取DOM对象 三、操作元素内容 <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8" /><meta http-equiv"X-UA-Compa…

基于Java的实验室预约管理系统设计与实现(源码+lw+部署文档+讲解等)

文章目录 前言具体实现截图论文参考详细视频演示为什么选择我自己的网站自己的小程序&#xff08;小蔡coding&#xff09;有保障的售后福利 代码参考源码获取 前言 &#x1f497;博主介绍&#xff1a;✌全网粉丝10W,CSDN特邀作者、博客专家、CSDN新星计划导师、全栈领域优质创作…

【数据结构】选择排序 堆排序(二)

目录 一&#xff0c;选择排序 1&#xff0c;基本思想 2&#xff0c; 基本思路 3&#xff0c;思路实现 二&#xff0c;堆排序 1&#xff0c;直接选择排序的特性总结&#xff1a; 2&#xff0c;思路实现 3&#xff0c;源代码 最后祝大家国庆快乐&#xff01; 一&#xf…

设计模式8、装饰者模式 Decorator

解释说明&#xff1a;动态地给一个对象增加一些额外的职责。就扩展功能而言&#xff0c;装饰模式提供了一种比使用子类更加灵活的替代方案 抽象构件&#xff08;Component&#xff09;&#xff1a;定义一个抽象接口以规范准备收附加责任的对象 具体构件&#xff08;ConcreteCom…

10OpenMP

OpenMP概述 通过线程实现并行化&#xff0c;与Pthread一样&#xff0c;是基于线程的共享内存库 与Pthread的不同 简而言之&#xff1a; Pthread更加底层&#xff0c;需要用户自己定义每一个线程的行为&#xff0c;OpenMP虽然更加简单&#xff0c;但是底层的线程交互实现很难 …

【单片机】13-实时时钟DS1302

1.RTC的简介 1.什么是实时时钟&#xff08;RTC&#xff09; &#xff08;rtc for real time clock) &#xff08;1&#xff09;时间点和时间段的概念区分 &#xff08;2&#xff09;单片机为什么需要时间点【一定的时间点干什么事情】 &#xff08;3&#xff09;RTC如何存在于…

【Git】Git 原理和使用

Git 一、Git 本地仓库1. 本地仓库的创建2. 配置 Git3. 工作区、暂存区、版本库4. 添加文件5. 查看 .git 文件6. 修改文件7. 版本回退8. 撤销修改9. 删除文件 二、分支管理1. 理解分支2. 创建分支3. 切换分支4. 合并分支5. 删除分支6. 合并冲突7. 分支管理策略8. bug 分支9. 强制…

基于Java的厨艺交流平台设计与实现(源码+lw+部署文档+讲解等)

文章目录 前言具体实现截图论文参考详细视频演示为什么选择我自己的网站自己的小程序&#xff08;小蔡coding&#xff09;有保障的售后福利 代码参考源码获取 前言 &#x1f497;博主介绍&#xff1a;✌全网粉丝10W,CSDN特邀作者、博客专家、CSDN新星计划导师、全栈领域优质创作…