Kubernetes设置污点以及容忍

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Kubernetes设置污点以及容忍相关的知识,希望对你有一定的参考价值。

K8S集群内有一台212专门用来做数据库服务器,磁盘是基于SSD。

1.设置212污点

kubectl taint node 172.17.10.212 disk=ssd:NoSchedule

2.数据库的deployment

    spec:
      tolerations:
      - key: "disk"
        operator: "Equal"
        value: "ssd"
        effect: "NoSchedule"
      nodeSelector:
        kubernetes.io/hostname: 172.17.10.212

这样子数据库就只会在212这台机器上跑,同时其他服务不会调度在这台。

kubectl taint node [node] key=value[effect]
其中[effect] 可取值: [ NoSchedule | PreferNoSchedule | NoExecute ]
NoSchedule :一定不能被调度。
PreferNoSchedule:尽量不要调度。
NoExecute:不仅不会调度,还会驱逐Node上已有的Pod。

查看节点的污点:
kubectl describe node/node_name |grep Taint

如何取消污点:
去除指定key及其effect:
kubectl taint nodes node_name key:[effect]- #(这里的key不用指定value)

去除指定key所有的effect:
kubectl taint nodes node_name key-

deploy容忍污点:
tolerations:

  • key: "disk"
    operator: "Equal" #Equal意味着这个值等于value,如果是Exists,则不需要填写value,只要有这个key就容忍
    value: "ssd"
    effect: "NoSchedule"

以上是关于Kubernetes设置污点以及容忍的主要内容,如果未能解决你的问题,请参考以下文章

k8s 污点和容忍

k8s 污点和容忍

k8s 污点和容忍

k8s 污点和容忍

Kubernetes——污点容忍故障排除

Kubernetes的污点(Taint)和容忍(Tolerations)