【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
相关推荐
iceland924 分钟前
kubeadm方式部署k8s集群
云原生·容器·kubernetes
tb_first16 小时前
k8sday11服务发现(2/2)
docker·云原生·容器·kubernetes·k8s
zxcxylong17 小时前
almalinux9.6系统:k8s可选组件安装(1)
云原生·容器·kubernetes·metrics·almalinux·hpa·vpa
一个天蝎座 白勺 程序猿1 天前
Apache IoTDB(4):深度解析时序数据库 IoTDB 在Kubernetes 集群中的部署与实践指南
数据库·深度学习·kubernetes·apache·时序数据库·iotdb
xiao-xiang1 天前
redis-集成prometheus监控(k8s)
数据库·redis·kubernetes·k8s·grafana·prometheus
MANONGMN1 天前
Kubernetes(K8s)常用命令全解析:从基础到进阶
云原生·容器·kubernetes
Johny_Zhao1 天前
基于 Docker 的 LLaMA-Factory 全流程部署指南
linux·网络·网络安全·信息安全·kubernetes·云计算·containerd·yum源·系统运维·llama-factory
陈陈CHENCHEN1 天前
【Kubernetes】在 K8s 上部署 Prometheus
kubernetes·prometheus
郝同学的测开笔记2 天前
从漏洞到防护:如何为你的CronJob添加RBAC安全层?
云原生·kubernetes·测试
deeper_wind3 天前
k8s-单主机Master集群部署+单个pod部署lnmp论坛服务(小白的“升级打怪”成长之路)
云原生·容器·kubernetes