全部文档
当前文档

暂无内容

如果没有找到您期望的内容,请尝试其他搜索词

文档中心

Pod反亲和

最近更新时间:2021-09-15 11:18:01

Pod反亲和

Pod反亲和策略可以决定工作负载的Pod不和哪些Pod部署在同一个拓扑域中,同时也可以基于已经运行在节点上的 Pod 的标签来限定 Pod 可以不被调度到哪个节点上。

  1. 登录容器服务控制台
  2. 在左侧导航栏中,选择集群,进入集群管理页面。
  3. 选择需要操作的集群,进入该集群操作页面。
  4. 选择工作负载 > Deployment,进入Deployment列表页。

注:您可根据实际需求选择Deployment、StatefulSet、DaemonSet。

  1. 单击页面左上角新建,进入创建流程第二步部署配置
  2. 点击高级配置,选择添加 PodAntiAffinity
  3. 在Pod反亲和设置中,依据Pod的标签进行业务需求的设置,单击确定,即可创建该策略。
    image.png

以下为Pod反亲和设置详情:

支持必须满足和尽量满足(硬约束Required/软约束Preferred)

参数 描述
必须满足 即硬约束,Pod的反亲和性调度必须要满足后续定义的约束条件,对应requiredDuringSchedulingIgnoredDuringExecution,您可以点击新增调度规则添加多条必须满足的规则,多个调度规则是逻辑或的关系,即只需要满足一条规则即可
尽量满足 即软约束,对应preferredDuringSchedulingIgnoredDuringExecution,Pod的反亲和性调度会尽量满足后续定义的约束条件。同时您可点击新增调度规则添加多条尽量满足的规则,无论是满足其中一条或者是都不满足都会进行调度

新增选择器

对应matchExpressions,您可以单击新增选择器添加多条选择器,多个选择器是逻辑与的关系,即需要满足全部选择器才能依据此条规则进行调度。

可设置参数

参数 描述
权重 尽量满足时可为规则设置权重值,权重值越高会被优先调度
命名空间 依据Pod的标签进行调度,所以会受到命名空间的约束
拓扑域 即topologyKey,用于指定调度时的作用域。拓扑域通过设置Node节点的标签,例如指定为kubernetes.io/hostname,以Node节点作为区分范围
查看应用列表 根据实际需求查看各命名空间下的应用,将可用的标签导入到亲和性配置中
标签名 对应工作负载的Pod标签,您可以手工填写,也可从应用列表中选择
操作符 可选值为In, NotIn, Exists, DoesNotExist
标签值 当操作符选择In或NotIn时,可以添加单个或多个value值;选择Exists或DoesNotExist时不需设置value值,即判断某个label是否存在
文档导读
纯净模式常规模式

纯净模式

点击可全屏预览文档内容
文档反馈