kubernetes亲和,反亲和、污点、容忍

目录

一、K8S调度

二、亲和与反亲和

1.pod和node

2.硬亲和和软亲和

三、容忍与污点

1.污点(taint)

(1)污点的组成     

(2)污点的设置和去除

2.容忍(tolerations) 

(1)Toleration 基本用法

(2)toleation

3.多污点与多容忍配置


一、K8S调度

       调度器通过kubernetes的list-watch机制来发现集群中新创建且尚未被调度到Node上的Pod。调度器会将发现的每一个未调度的Pod调度到一个合适的Node上来运行。
        kube-scheduler是Kubernetes集群的默认调度器,并且是集群控制面的一部分。如果你真的希望或者有这方面的需求,kube-scheduler在设计上是允许你自己写一个调度组件并替换原有的kube-scheduler。
在做调度决定时需要考虑的因素包括:单独和整体的资源请求、硬件/软件/策略限制、亲和以及反亲和要求、数据局域性、负载间的干扰等等。

二、亲和与反亲和

1.pod和node

        一般情况下,我们部署的pod是通过的自动调度策略来选择节点的,默认情况下调度器考虑的是资源足够,并且负载尽量平衡,但是有的时候需要能够更加细粒度的去控制Pod的调度,比如我们内部的一些服务gitlab 之类的也是跑在kubernetes集群上的,我们就不希望对外的的一些服务和内部的服务跑在同一节点上了,担心内部服务对外部服务产生影响;但是有的时候我们的服务之间交流比较频繁,有希望能够将这两个服务的pod调度到同一节点上,这就需要用到kubernetes李面的一个概念:亲和性和反亲和性。

       亲和性有分为节点亲和性(nodeAffinity和nodeAntiAffinity)和pod亲和性(podAffinity和podAntiAffinity)

亲和性,in代表要调度到有这个标签的位置
反亲和性,in代表不要调度到有这个标签的位置

2.硬亲和和软亲和

preferredDuringSchedulingIgnoredDuringExecution 软亲和

软策略:意思就是尽量不要讲pod调度到匹配到的节点,但是如果没有不匹配的节点的话,也可以调度到匹配到的节点。
requiredDuringSchedulingIgnoredDuringExecution 硬亲和

硬策略:意思就是必须调度到满足条件的节点上,否则就会pending。
不管是使用那种方式,最终还是要依赖label标签

kubectl get pods -n company ai-action-statistic-gray-86465f9c4b-hdfk4 -oyaml | grep nodeSelector -B 5 -A 5
  uid: ed47f094-f70a-45ed-b7dd-d46f2d01986f
spec:
  affinity:
    nodeAffinity:
      requiredDuringSchedulingIgnoredDuringExecution:   硬策略
        nodeSelectorTerms:
        - matchExpressions:
          - key: node-role.kubernetes.io/gray
            operator: In
            values:
            - gray
      preferredDuringSche
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值