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

1. 什么是Taint

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

通俗点说:

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

【Taint 的结构】:
一个 Taint 由三个部分组成:

key=value:effect

例如:

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 的含义是:

  • key: node-role.kubernetes.io/master

  • effect: NoSchedule(不允许 Pod 调度)

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

1.2 普通 Pod 默认不容忍 master taint

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


## 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:

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
TolerationPod 对 taint 的容忍toleration: key=node-role.kubernetes.io/master
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值