【k8s】Taint污点)、Toleration(容忍)

文章目录

  • [1. 什么是Taint](#1. 什么是Taint)
    • [1.1 Master 节点的 Taint 示例](#1.1 Master 节点的 Taint 示例)
    • [1.2 普通 Pod 默认不容忍 master taint](#1.2 普通 Pod 默认不容忍 master taint)
    • [1.3 示例:Pod 添加 toleration 来容忍 master taint](#1.3 示例:Pod 添加 toleration 来容忍 master taint)
  • [2. Taint 和 Label 概念区别](#2. Taint 和 Label 概念区别)

1. 什么是Taint

Taint(污点)是 Kubernetes 给节点贴的"禁止调度标签",它告诉调度器:"除非 Pod 明确表示可以容忍,否则不要把它调度到这个节点上。"

通俗点说:

🧱 节点说:"我有特殊情况,不欢迎一般 Pod,除非你能接受我(加 toleration)。"

【Taint 的结构】:

一个 Taint 由三个部分组成:

text 复制代码
key=value:effect

例如:

text 复制代码
node-role.kubernetes.io/master=:NoSchedule

含义如下:

字段 解释
key 污点的名称,比如节点角色、资源状态
value 可选,比如说 taint 的值
effect 生效方式:见下方解释

【Taint 的 effect(生效方式)】:

effect 意义
NoSchedule 不调度新的 Pod 到这个节点(除非 Pod 有 toleration)
PreferNoSchedule 尽量不要调度,但不是强制的(调度器尽量避免)
NoExecute 不仅不调度新的 Pod,还会驱逐已经在运行但不容忍的 Pod

1.1 Master 节点的 Taint 示例

你可以运行下面命令看看 master 节点带了什么 taint:

复制代码
kubectl describe node <master-node-name> | grep -i taint

结果通常类似这样:

复制代码
Taints: node-role.kubernetes.io/master:NoSchedule

这个 taint 的含义是:

一般情况下,master节点不希望pod部署到其上面,因此会增加污点

1.2 普通 Pod 默认不容忍 master taint

如果你的 Pod 没有添加 toleration,它就会被默认 scheduler 拒之门外:

yaml 复制代码
## 1.3 普通 Pod(默认不带 toleration)
apiVersion: v1
kind: Pod
metadata:
  name: test-pod
spec:
  containers:
  - name: busybox
    image: busybox
    command: ["sleep", "3600"]

这个 Pod 无法调度到 master 节点。

1.3 示例:Pod 添加 toleration 来容忍 master taint

如果你想让这个 Pod 可以调度到 master 节点,需要这样添加 toleration:

yaml 复制代码
apiVersion: v1
kind: Pod
metadata:
  name: test-pod
spec:
  tolerations:
    - key: "node-role.kubernetes.io/master"
      operator: "Exists"
      effect: "NoSchedule"
  containers:
    - name: busybox
      image: busybox
      command: ["sleep", "3600"]

2. Taint 和 Label 概念区别

对象 用于 示例
Label 选择目标节点(配合 nodeSelector/affinity) node-role.kubernetes.io/master=true
Taint 驱逐策略,Pod不能调度上去 node-role.kubernetes.io/master:NoSchedule
Toleration Pod 对 taint 的容忍 toleration: key=node-role.kubernetes.io/master
相关推荐
爱的叹息7 小时前
本地(NAS/服务器)与云端(Docker/Kubernetes)部署详解与对比
服务器·docker·kubernetes
bst@微胖子10 小时前
K8S探针的应用
云原生·容器·kubernetes
时迁24712 小时前
【k8s】docker、k8s、虚拟机的区别以及使用场景
docker·容器·kubernetes
Ares-Wang13 小时前
kubernetes》》k8s》》证书有效期
云原生·容器·kubernetes
rider18917 小时前
【3】CICD持续集成-k8s集群中安装Jenkins-agent(主从架构)
ci/cd·kubernetes·jenkins
Justice link17 小时前
K8S安全认证
java·安全·kubernetes
时迁24717 小时前
【k8s】LVS/IPVS的三种模式:NAT、DR、TUN
kubernetes·k8s·lvs
liudongyang12318 小时前
k8s-1.28.10 安装metrics-server
云原生·容器·kubernetes
大新新大浩浩18 小时前
arm64适配系列文章-第一章-arm64环境上kubesphere和k8s的部署
云原生·容器·kubernetes