当前位置: 首页 > news >正文

k8s(三): 基本概念-ReplicaSet与Deployment

PeplicaSet

ReplicaSet 的目的是维护一组在任何时候都处于运行状态的 Pod 副本的稳定集合,通常用来保证给定数量的、完全相同的 Pod 的可用性。

最佳实践

Deployment 是一个可以拥有 ReplicaSet 并使用声明式方式在服务器端完成对 Pod 滚动更新的对象。 尽管 ReplicaSet 可以独立使用,目前它们的主要用途是提供给 Deployment 作为编排 Pod 创建、删除和更新的一种机制。当使用 Deployment 时,不必关心如何管理它所创建的 ReplicaSet,Deployment 拥有并管理其 ReplicaSet。 因此,建议在需要 ReplicaSet 时使用 Deployment。

Deployment

作用: Deployment 为 Pod 和 ReplicaSet 提供声明式的更新能力。

使用

负责启动3个nginx Pod的 Deployment用例

nginx-deployment.yaml

apiVersion: apps/v1
kind: Deployment
metadata:name: nginx-deploymentlabels:app: nginx
spec:replicas: 3selector:matchLabels:app: nginxtemplate:metadata:labels:app: nginxspec:containers:- name: nginximage: nginx:1.14.2ports:- containerPort: 80
  1. 创建deployment

    kubectl apply -f ./nginx-deployment.yaml
    
  2. 查看状态

    kubectl get deployments |grep nginx-deployment
    

在这里插入图片描述
参数说明:

  • NAME 列出了名字空间中 Deployment 的名称。
  • READY 显示应用程序的可用的“副本”数。显示的模式是“就绪个数/期望个数”。
  • UP-TO-DATE 显示为了达到期望状态已经更新的副本数。
  • AVAILABLE 显示应用可供用户使用的副本数。
  • AGE 显示应用程序运行的时间。
  1. 查看deployment的上线状态

    kubectl rollout status deployment/nginx-deployment
    
  2. 查看Deployment创建的ReplicaSet

    kubectl get rs
    
  3. 查看创建的pod

    kubectl get pods
    
  4. 查看deployment启动日志,pod启动日志

    kubectl describe deployment <deployment-name>
    kubectl describe pod <pod-name>
    

更新与回滚Deployment

  1. 修改镜像版本

    kubectl set image deployment/nginx-deployment nginx=nginx:1.161
    
  2. 检查Deployment 上线历史

    kubectl rollout history deployment/nginx-deployment
    

    输出类似于

    deployments "nginx-deployment"
    REVISION    CHANGE-CAUSE
    1           kubectl apply --filename=https://k8s.io/examples/controllers/nginx-deployment.yaml
    2           kubectl set image deployment/nginx-deployment nginx=nginx:1.16.1
    3           kubectl set image deployment/nginx-deployment nginx=nginx:1.161
    

CHANGE-CAUSE 的内容是从 Deployment 的 kubernetes.io/change-cause 注解复制过来的。 复制动作发生在修订版本创建时。可以通过以下方式设置 CHANGE-CAUSE 消息:

  • 使用 kubectl annotate deployment/nginx-deployment kubernetes.io/change-cause="image updated to 1.16.1" 为 Deployment 添加注解。
  • 手动编辑资源的清单。
  1. 要查看修订历史的详细信息

    kubectl rollout history deployment/nginx-deployment --revision=2
    
  2. 回滚到上一个修改的版本

    kubectl rollout undo deployment/nginx-deployment
    
  3. 回滚到指定版本

    kubectl rollout undo deployment/nginx-deployment --to-revision=2
    

缩放Deployment

  1. 缩放指定大小

    kubectl scale deployment/nginx-deployment --replicas=10
    
  2. 自动缩放

    kubectl autoscale deployment/nginx-deployment --min=10 --max=15 --cpu-percent=80
    

    Deployment 设置自动缩放器,并基于现有 Pod 的 CPU 利用率选择要运行的 Pod 个数下限和上限。

暂定运行中的deployment

kubectl rollout pause deployment/nginx-deployment

此时可以更新deployment

恢复deployment

kubectl rollout resume deployment/nginx-deployment

不可以回滚处于暂停状态的 Deployment,除非先恢复其执行状态

deployment的状态

  • Progressing(进行中)
  • Complete(已完成)
  • Failed(失败)

进行中的Deployment

执行下面的任务期间,Kubernetes 标记 Deployment 为进行中(Progressing):

  • Deployment 创建新的 ReplicaSet
  • Deployment 正在为其最新的 ReplicaSet 扩容
  • Deployment 正在为其旧有的 ReplicaSet(s) 缩容
  • 新的 Pod 已经就绪或者可用(就绪至少持续了MinReadySeconds 秒)。

当上线过程进入“Progressing”状态时,Deployment 控制器会向 Deployment 的 .status.conditions 中添加包含下面属性的状况条目:

  • type: Progressing
  • status: "True"
  • reason: NewReplicaSetCreated | reason: FoundNewReplicaSet | reason: ReplicaSetUpdated

可以使用 kubectl rollout status 监视 Deployment 的进度。

完成的 Deployment

当 Deployment 具有以下特征时,Kubernetes 将其标记为完成(Complete);

  • 与 Deployment 关联的所有副本都已更新到指定的最新版本,这意味着之前请求的所有更新都已完成。
  • 与 Deployment 关联的所有副本都可用。
  • 未运行 Deployment 的旧副本。

当上线过程进入“Complete”状态时,Deployment 控制器会向 Deployment 的 .status.conditions 中添加包含下面属性的状况条目:

  • type: Progressing
  • status: "True"
  • reason: NewReplicaSetAvailable

这一 Progressing 状况的状态值会持续为 "True",直至新的上线动作被触发。 即使副本的可用状态发生变化(进而影响 Available 状况),Progressing 状况的值也不会变化。

可以使用 kubectl rollout status 检查 Deployment 是否已完成。 如果上线成功完成,kubectl rollout status 返回退出代码 0。

失败的 Deployment

Deployment 可能会在尝试部署其最新的 ReplicaSet 受挫,一直处于未完成状态。 造成此情况一些可能因素如下:

  • 配额(Quota)不足
  • 就绪探测(Readiness Probe)失败
  • 镜像拉取错误
  • 权限不足
  • 限制范围(Limit Ranges)问题
  • 应用程序运行时的配置错误

检测此状况的一种方法是在 Deployment 规约中指定截止时间参数: (.spec.progressDeadlineSeconds)。 .spec.progressDeadlineSeconds 给出的是一个秒数值,Deployment 控制器在(通过 Deployment 状态) 标示 Deployment 进展停滞之前,需要等待所给的时长。

以下 kubectl 命令设置规约中的 progressDeadlineSeconds,从而告知控制器 在 10 分钟后报告 Deployment 的上线没有进展:

kubectl patch deployment/nginx-deployment -p '{"spec":{"progressDeadlineSeconds":600}}'

输出类似于:

deployment.apps/nginx-deployment patched

超过截止时间后,Deployment 控制器将添加具有以下属性的 Deployment 状况到 Deployment 的 .status.conditions 中:

  • type: Progressing
  • status: "False"
  • reason: ProgressDeadlineExceeded

这一状况也可能会比较早地失败,因而其状态值被设置为 "False", 其原因为 ReplicaSetCreateError。 一旦 Deployment 上线完成,就不再考虑其期限。

清理策略

可以在 Deployment 中设置 .spec.revisionHistoryLimit 字段以指定保留此 Deployment 的多少个旧的ReplicaSet。其余的 ReplicaSet 将在后台被垃圾回收。 默认情况下,此值为 10。

说明:

显式将此字段设置为 0 将导致 Deployment 的所有历史记录被清空,因此 Deployment 将无法回滚。

相关文章:

  • 深度学习 -- 神经网络
  • shell 脚本计算距离最近的坐标
  • 1.0 十大经典排序算法
  • 基于运算放大器的电压采集电路
  • Maven安装
  • 计算机组成学习-计算机系统概述总结
  • 一篇带你串通数据结构
  • python+pytest接口自动化(6)-请求参数格式的确定
  • 数据结构与算法-静态查找表
  • Fiddler抓包工具之高级工具栏中的重定向AutoResponder的用法
  • 【网络安全技术】实体认证技术Kerberos
  • Hdoop学习笔记(HDP)-Part.02 核心组件原理
  • 【linux】信号——信号保存+信号处理
  • go使用aes加密算法
  • 详细学习Pyqt5的20种输入控件(Input Widgets)
  • 2017 前端面试准备 - 收藏集 - 掘金
  • 2017年终总结、随想
  • Bootstrap JS插件Alert源码分析
  • CSS实用技巧
  • If…else
  • interface和setter,getter
  • JavaScript设计模式与开发实践系列之策略模式
  • java中的hashCode
  • open-falcon 开发笔记(一):从零开始搭建虚拟服务器和监测环境
  • PHP的Ev教程三(Periodic watcher)
  • React Transition Group -- Transition 组件
  • spring boot下thymeleaf全局静态变量配置
  • ucore操作系统实验笔记 - 重新理解中断
  • Vue 2.3、2.4 知识点小结
  • 二维平面内的碰撞检测【一】
  • 工作中总结前端开发流程--vue项目
  • 基于Mobx的多页面小程序的全局共享状态管理实践
  • 理解 C# 泛型接口中的协变与逆变(抗变)
  • 入职第二天:使用koa搭建node server是种怎样的体验
  • 山寨一个 Promise
  • 思否第一天
  • 微信端页面使用-webkit-box和绝对定位时,元素上移的问题
  • 线上 python http server profile 实践
  • 一天一个设计模式之JS实现——适配器模式
  • [Shell 脚本] 备份网站文件至OSS服务(纯shell脚本无sdk) ...
  • 带你开发类似Pokemon Go的AR游戏
  • ​草莓熊python turtle绘图代码(玫瑰花版)附源代码
  • ###51单片机学习(1)-----单片机烧录软件的使用,以及如何建立一个工程项目
  • #周末课堂# 【Linux + JVM + Mysql高级性能优化班】(火热报名中~~~)
  • (2015)JS ES6 必知的十个 特性
  • (BFS)hdoj2377-Bus Pass
  • (二)hibernate配置管理
  • (六)Hibernate的二级缓存
  • (三分钟)速览传统边缘检测算子
  • (十八)用JAVA编写MP3解码器——迷你播放器
  • (转)Oracle存储过程编写经验和优化措施
  • .[hudsonL@cock.li].mkp勒索加密数据库完美恢复---惜分飞
  • .gitignore文件---让git自动忽略指定文件
  • .NET CF命令行调试器MDbg入门(三) 进程控制
  • .net core 实现redis分片_基于 Redis 的分布式任务调度框架 earth-frost