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

K8S学习之基础十四:k8s中Deployment控制器概述

Deployment控制器概述:

Deployment控制器是k8s中最常用的资源对象,为Replicaset和Pod创建提供了一种声明式的定义方法,在Deployment对象中描述一个期望的状态,Deployment控制器就会按照一定的控制速率把实际状态改成期望状态,通过定义一个Deployment控制器会创建一个新的ReplicaSet控制器,通过ReplicaSet创建Pod。删除Deployment控制器,也会删除Deployment控制器下对应的Replicaset控制器和Pod资源。

使用Deployment控制器而不是直接使用ReplicaSet,是因为Deployment对象拥有很多ReplicaSet没有的特性,比如滚动升级、金丝雀发布、蓝绿部署和回滚等。

声明式定义是指直接修改资源清单yaml文件,然后通过 kubectl apply -f *.yaml的方式,就可以更改资源

Deployment是建立在rs之上的一个控制器,可以管理多个rs,每次更新镜像版本,都会生成一个新的rs,把旧的rs替换掉,多个rs同时存在,但是只有一个rs运行

rs v1控制三个pod,删除一个pod,在rs v2上重新建立一个,依次类推,直到全部都是由rs v2控制,如果rs v2有问题,还可以回滚,Deployment是建构在rs之上的,多个rs组成一个Deployment,但是只有一个rs处于活跃状态.

Deployment工作原理:如何管理rs和pod

通过Deployment对象,可以轻松做到以下事情:

  1. 创建ReplicaSet和Pod
  2. 滚动升级和回滚应用
  3. 平滑扩容和缩容
  4. 暂停和继续Deployment

更新策略中的rollingupdate计算:

maxSurge(默认25%):最大允许个数(直接用)或百分比(往上加), 如 5+5*25%计算为 7

maxUnavailable(默认25%):最小允许个数(直接用)或百分比(往下减), 如 5-5*25%  计算为 4

Deployment的yaml文件:

vi deploy-demo.yaml
kind: Deployment
metadata:
  name: myapp-v1
spec:
  replicas: 2
  selector:
    matchLabels:
      app: myapp
      version: v1
  template:
    metadata:
      labels:
        app: myapp
        version: v1
    spec:
      containers:
      - name: myapp
        image: 172.16.80.140/myapp/myapp:v1
        imagePullPolicy: IfNotPresent
        ports:
        - containerPort: 80

三者的名字也有关系:deploy-->replicas-->pod

访问pod返回v1版本


http://www.kler.cn/a/576217.html

相关文章:

  • 【五.LangChain技术与应用】【31.LangChain ReAct Agent:反应式智能代理的实现】
  • 从开源大模型工具Ollama存在安全隐患思考企业级大模型应用如何严守安全红线
  • Process-based Self-Rewarding Language Models 论文简介
  • React基础之组件
  • 开发环境搭建-完善登录功能
  • 系统架构评估方法-SAAM方法
  • C++20的简写函数模板
  • 初次使用 IDE 搭配 Lombok 注解的配置
  • Android APP 启动流程详解(含冷启动、热启动)
  • html流程图
  • RabbitTemplate类介绍、应用场景和示例代码
  • 在使用 router-link 进行路由跳转时,A页面跳转到A页面,资源要重新加载吗
  • 物联网-铁路局“管理工区一张图”实现方案
  • xxx **5. 物理安全** 详细解读
  • mybatis报错org/apache/commons/lang3/tuple/Pair] with root cause
  • React基础之Redux
  • wx122基于ssm+vue+uniapp的食堂线上预约点餐系统小程序
  • 【Python机器学习】1.7. 逻辑回归理论(进阶):多维度(因子)逻辑回归问题、决策边界、交叉熵损失函数、最小化损失函数
  • 26-小迪安全-模块引用,mvc框架,渲染,数据联动0-rce安全
  • go切片定义和初始化