k8s ReplicaSet

ReplicaSet 是替代 ReplicationController 的,ReplicaSet 的行为与 ReplicationController 完全相同, 但pod 选择器的表达能力更强。

ReplicaSet 和 ReplicationController 的区别:

ReplicationController 的标签选择器只允许包含某个标签的匹配 pod,但 ReplicaSet 的选择器还允许匹配缺少某个标签的 pod, 或包含特定标签名的 pod。

单个 ReplicationController 无法将 pod 与标签 env=prod 和 env=dev 同时匹配。它只能匹配带有 env=prod 或 env=dev的 pod。但一个 ReplicaSet 可以匹配两组 pod 并将它们视为一个大组。

无论 ReplicationController 的值如何,ReplicationController 都无法仅基于标签名的存在来匹配 pod, 而 ReplicaSet 则可以。 例如, ReplicaSet 可匹配所有包含名为 env 的标签的 pod, 无论ReplicaSet 的实际值是什么(可以理解为 env= *)。

ReplicaSet 相对于 ReplicationController 的主要改进是它更具表达力的标签选择器。

可以给选择器添加额外的表达式,每个表达式都必须包含一个 key、一个 operator、并且可能还有一个 values 的列表。

  • In:Label 的值必须与其中一个指定的 values 匹配
  • NotIn:Label 的值与任何指定的 values 不匹配。
  • Exists:pod 必须包含一个指定名称的标签,不应指定 values 字段。
  • DoesNotExist:pod 不得包含有指定名称的标签,不应指定 values 字段。

如果指定了多个表达式,则所有这些表达式都必须为 true 才能使选择器与 pod 匹配。

相关推荐
全是操作3 小时前
k8s scheduler源码阅读
云原生·容器·kubernetes
obboda5 小时前
Docker基础入门
运维·docker·云原生·容器·eureka
cooldream20095 小时前
Docker Desktop 安装与使用详解
运维·docker·容器
川石课堂软件测试7 小时前
涨薪技术|Kubernetes(k8s)之Service服务
功能测试·adb·docker·云原生·容器·kubernetes·单元测试
钰紫薇7 小时前
玩转K8S,轻松部署SpringBoot项目,实现hello K8s
运维·kubernetes
RedCong7 小时前
k8s之PodDisruptionBudget详解
云原生·容器·kubernetes
{⌐■_■}8 小时前
【Kubernets】Kubernetes 的基础知识,Pod是什么? 和容器的关系?多个容器如何在同一个 Pod 里协作?
云原生·容器·kubernetes
hxdcxy8 小时前
docker企业级事例部署phpmyadmin和MySQL
mysql·docker·容器
川石课堂软件测试8 小时前
涨薪技术|Kubernetes(k8s)之Service服务类型
mysql·nginx·docker·容器·贪心算法·kubernetes·tomcat
MinIO官方账号8 小时前
使用 AIStor、MLflow 和 KServe 将模型部署到 Kubernetes
云原生·容器·kubernetes