【Kubernetes】污点和容忍

一、概述

在 Kubernetes(k8s)中,污点(Taints) 是定义在节点上的一种机制,用于拒绝某些 Pod 调度到该节点,除非这些 Pod 具有对应的容忍度(Tolerations)。污点可以用来控制 Pod 的调度行为,确保特定的 Pod 不会被分配到不合适的节点上。

容忍(Tolerations) 是与污点(Taints)相对应的一种机制。容忍允许 Pod 被调度到带有特定污点的节点上,或者在节点被添加了特定污点后,允许已经运行在该节点上的 Pod 继续运行。简而言之,容忍是对污点的一种"豁免"机制。

污点的组成

  • Key:污点的键,用于标识污点的类型。

  • Value:污点的值,通常与 Key 一起用于标识污点的具体属性。

  • Effect:污点的作用效果,有以下三种类型:

    • NoSchedule:没有配置此污点容忍度的新 Pod 不能调度到此节点,但节点上已存在的 Pod 不受影响。

    • PreferNoSchedule:没有配置此污点容忍度的新 Pod 尽量不要调度到此节点,但如果找不到合适的节点,仍然会调度到此节点。

    • NoExecute:没有配置此污点容忍度的新 Pod 不能调度到此节点,同时节点上已存在的 Pod 也会被驱逐。

污点的使用场景

  • 独占节点:通过给节点添加污点,可以确保只有特定的 Pod 能够调度到该节点。例如,某些节点可能具有特殊的硬件资源(如 GPU),可以通过污点和容忍度来限制只有特定的 Pod 能够使用这些节点。

  • 驱逐 Pod :当节点出现故障或资源不足时,Kubernetes 会自动为节点添加污点(如 node.kubernetes.io/memory-pressure),并使用 NoExecute 作为排斥等级,此时没有设置此类污点容忍度的 Pod 会被驱逐。

污点的操作

  • 添加污点 :可以使用 kubectl taint 命令为节点添加污点。例如:

    复制代码
    kubectl taint nodes <node-name> <key>=<value>:<effect>
  • 查看污点 :可以使用 kubectl describe node 命令查看节点的污点信息:

    bash 复制代码
    kubectl describe node <node-name> | grep 'Taints'
  • 删除污点 :可以使用 kubectl taint 命令删除节点的污点:

    bash 复制代码
    kubectl taint nodes <node-name> <key>=<value>:<effect>-

二、PreferNoSchedule

bash 复制代码
kubectl taint node node1 tag=huaiche:PreferNoSchedule

三、NoSchedule

bash 复制代码
kubectl taint node node1 tag=huaiche:NoSchedule

四、NoExecute

bash 复制代码
kubectl taint node node1 tag=huaiche:NoExecute

五、编写容忍对应污点的Pod.yaml

bash 复制代码
apiVersion: v1
kind: Pod
metadata:
  name: my-pod
spec:
  tolerations:
  - key: "check-nginx"
    operator: "Equal"
    value: "web"
    effect: "NoSchedule"
  containers:
  - name: my-container
    image: my-image
相关推荐
听风吟丶15 分钟前
云原生智能告警与故障自愈实战:从被动响应到主动运维
运维·云原生
是Yu欸18 分钟前
②【openFuyao】融合云原生与高性能计算
云原生·云计算·高性能计算·openfuyao
Gold Steps.28 分钟前
K8S云原生部署Harbor镜像仓库与镜像漏扫Trivy的使用
云原生·容器·kubernetes
峰顶听歌的鲸鱼29 分钟前
14.docker:镜像
运维·笔记·docker·容器·学习方法
java_logo34 分钟前
Apache RocketMQ Docker 容器化部署指南
运维·docker·容器·kafka·kubernetes·apache·rocketmq
by__csdn34 分钟前
第二章 (.NET Core环境搭建)第三节( Visual Studio for Mac)
ide·kubernetes·c#·asp.net·.net·.netcore·visual studio
麻辣兔变形记12 小时前
深入理解微服务下的 Saga 模式——以电商下单为例
微服务·云原生·架构
菜萝卜子13 小时前
Kubernetes metrics-server 部署与全场景使用指南
云原生·容器·kubernetes
阿里云云原生14 小时前
祝贺东航首飞全球最长单程航线!通义千问和 AI 网关助力推出首个行程规划 Agent
云原生
腾讯云中间件15 小时前
Kafka 集群上云新突破:腾讯云 CKafka 联邦迁移方案
云原生·kafka·消息队列