专栏首页耕耘实录深入浅出 Kubernetes:浅谈 Deployment 和 ReplicaSet

深入浅出 Kubernetes:浅谈 Deployment 和 ReplicaSet

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。

本文链接:https://blog.csdn.net/solaraceboy/article/details/98883311

文章目录

深入浅出 Kubernetes:浅谈 Deployment 和 ReplicaSet

一 背景

Deployment 和 ReplicaSet 是 Kubernetes 中两个比较重要的对象,本文简单地讨论了他们之间的一些区别与联系。

二 Deployment

apiVersion: apps/v1
kind: Deployment
metadata:
  name: deployment-gysl
spec:
  replicas: 2
  selector:
    matchLabels:
      app-1: nginx
      app-2: busybox
  template:
    metadata:
      labels:
        app-1: nginx
        app-2: busybox
    spec:
      containers:
        - name: app-1
          image: nginx:1.16.0
          imagePullPolicy: Always
          ports:
            - containerPort: 80
            - containerPort: 8080
        - name: app-2
          image: busybox
          imagePullPolicy: Never
          command: ['/bin/sh', '-c']
          args:
            - while :;do sleep 20;done

这是一个编排得非常简单的 Deployment,确保携带 app-1=nginx 和 app-2=busybox 标签的 Pod 的个数等于 spec.replicas 指定的总数 2 个。也就是说在这个 Deployment 的 Pod 数量大等于2时,就会有 Pod 被删除,反之则会有 Pod 被创建。

这个 Deployment 由2个部分构成,例子中的 yaml 第1-10行定义了 Deployment 控制器,第10行以后的内容则定义了被控制的 Pod ,template 后面这一部分我们会发现跟之前的 Pod 定义大同小异。

此处顺便提一条命令(更新 Deployment 的镜像):

kubectl set image deployment/deployment-gysl app-1=nginx:latest

这个命令还可以更新以下对象:

  env            Update environment variables on a pod template
  image          更新一个 pod template 的镜像
  resources      在对象的 pod templates 上更新资源的 requests/limits
  selector       设置 resource 的 selector
  serviceaccount Update ServiceAccount of a resource
  subject        Update User, Group or ServiceAccount in a RoleBinding/ClusterRoleBinding

三 ReplicaSet

apiVersion: apps/v1
kind: ReplicaSet
metadata:
  name: replica-set-gysl
spec:
  selector:
    matchLabels:
      app: nginx
  replicas: 2
  template:
    metadata:
      name: nginx
      labels:
        app: nginx
    spec:
      containers:
        - name: nginx
          image: nginx:latest

一个 ReplicaSet 对象就是由副本数目的定义和一个 Pod 模板组成的, 它的定义就是 Deployment 的一个子集。Deployment 控制器实际操纵的是 ReplicaSet 对象,而不是 Pod 对象。

ReplicaSet 负责通过“控制器模式”,保证系统中 Pod 的个数永远等于指定的个数(比如,2 个)。这也正是 Deployment 只允许容器的 restartPolicy=Always 的主要原因:只有在容器能保证自己始终是 Running 状态的前提下,ReplicaSet 调整 Pod 的个数才有意义。

Deployment 通过“控制器模式”,来操作 ReplicaSet 的个数和属性,进而实现“水平扩展 / 收缩”和“滚动更新”这两个编排动作。

四 其他

在之前的文章中已经讨论过 Kubernetes 中的滚动更新,这是 Deployment 控制器与 ReplicaSet 的最大不同之处,也是 Deployment 被广泛使用的最主要原因。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • Docker初体验,创建并导出第一个本地镜像

    版权声明:本文为耕耘实录原创文章,各大自媒体平台同步更新。欢迎转载,转载请注明出处,谢谢

    耕耘实录
  • Docker极简入门

    版权声明:本文为耕耘实录原创文章,各大自媒体平台同步更新。欢迎转载,转载请注明出处,谢谢

    耕耘实录
  • Linux系统下漏洞扫描、评估工具OpenVAS9的安装与使用

    版权声明:本文为耕耘实录原创文章,各大自媒体平台同步更新。欢迎转载,转载请注明出处,谢谢。

    耕耘实录
  • 《软件工程之美》打卡第七周

    本周正式回归正常的办公场所,关于远程办公和公司办公我只能说各有各的好坏,说实话我会更偏向在公司办公,后面有机会写篇文章分享下。本周继续专栏学习计划,目前已经进展...

    用户1130025
  • Python3快速入门(十五)——Pan

    如果要将自定义函数或其它库函数应用于Pandas对象,有三种使用方式。pipe()将函数用于表格,apply()将函数用于行或列,applymap()将函数用于...

    py3study
  • 从入门到跑路之Kubernetes(九)

    “编排“,应该是Kubernetes项目最核心的功能了,先来看一看”控制器“模型。

    周萝卜
  • AI化身空间站故障排查小助手​!借助AI和声音实现未雨绸缪

    我们都在电影中见过这种场景,例如在潜艇或宇宙飞船上,总工程师会突然竖起耳朵听背景嗡嗡声并说“出问题了”。博世希望教会计算机在现实生活中做到这一点,并到国际空间站...

    大数据文摘
  • “玄关”与“开机页”

    本文跨界思考室内设计中的“玄关”空间与手机APP“开机页”之间的异同点,思考互相借鉴的可能。 ——这是一篇符合本公众号“设计Mix科技”出发点的文章。 1、...

    mixlab
  • 数据库选型时必知的存储引擎基础

    在评估和选型数据库的时候,人们往往将重点放在数据建模的灵活性,一致性保证,线性可伸缩性,容错性,低延迟,高吞吐量和易于管理等方面。但怎么才能评判出这些指标呢?很...

    ImportSource
  • 了解Vuex状态管理模式的理解强化指南

    Vuex是什么呢?它是Vue的状态管理模式,在使用vue的时候,需要在vue中各个组件之间传递值是很痛苦的,在vue中我们可以使用vuex来保存我们需要管理的状...

    桃翁

扫码关注云+社区

领取腾讯云代金券