当前位置: 首页 > news >正文

k8s概念-亲和力与反亲和力

回到目录 

亲和力 Affinity

对部署调度时的优先选择

分为

  • 节点亲和力

  • pod亲和力

  • pod反亲和力

节点亲和力 NodeAffinity 

进行 pod 调度时,优先调度到符合条件的亲和力节点上

可配置 硬亲和力和软亲和力

  • RequiredDuringSchedulingIgnoredDuringExecution

    硬亲和力:即支持必须部署在指定的节点上,也支持必须不部署在指定的节点上

  • PreferredDuringSchedulingIgnoredDuringExecution

    尽量部署在满足条件的节点上,或尽量不要部署在被匹配的节点上

apiVersion: v1
kind: Pod
metadata:name: with-node-affinity
spec:affinity: # 亲和力配置nodeAffinity: # 节点亲和力requiredDuringSchedulingIgnoredDuringExecution: # 节点必须匹配下方配置nodeSelectorTerms: # 选择器- matchExpressions: # 匹配表达式- key: topology.kubernetes.io/zone # 匹配 label 的 keyoperator: In # 匹配方式,只要匹配成功下方的一个 value 即可values:- antarctica-east1 # 匹配的 value- antarctica-west1 # 匹配的 valuepreferredDuringSchedulingIgnoredDuringExecution: # 节点尽量匹配下方配置- weight: 1 # 权重[1,100],按照匹配规则对所有节点累加权重,最终之和会加入优先级评分,优先级越高被调度的可能性越高preference:matchExpressions: # 匹配表达式- key: another-node-label-key # label 的 keyoperator: In # 匹配方式,满足一个即可values:- another-node-label-value # 匹配的 value
#      - weight: 20......containers:- name: with-node-affinityimage: pause:2.0

operator类型

  • In

    部署在满足条件的节点上

  • NotIn

    匹配不在条件中的节点,实现节点反亲和性

  • Exists

    只要存在 key 名字就可以,不关心值是什么

  • DoesNotExists

    匹配指定 key 名不存在的节点,实现节点反亲和性

  • Gt

    value 为数值,且节点上的值小于指定的条件

  • Lt

    value 为数值,且节点上的值大于指定条件

pod亲和力 PodAffinity 和 pod反亲和力PodAnitAffinity

将与指定 pod 亲和力相匹配的 pod 部署在同一节点

即与pod比较进行亲和

可配置 硬亲和力和软亲和力

  • 硬亲和力

    RequiredDuringSchedulingIgnoredDuringExecution

    必须将应用部署在一块

  • 软亲和力

    PreferredDuringSchedulingIgnoredDuringExecution

    尽量将应用部署在一块

pod反亲和力  尽量将与指定 pod 反亲和力相匹配的 pod 部署在不同节点

apiVersion: v1
kind: Pod
metadata:name: with-pod-affinity
spec:affinity: # 亲和力配置podAffinity: # pod 亲和力配置requiredDuringSchedulingIgnoredDuringExecution: # 当前 pod 必须匹配到对应条件 pod 所在的 node 上- labelSelector: # 标签选择器matchExpressions: # 匹配表达式- key: security # 匹配的 keyoperator: In # 匹配方式values: # 匹配其中的一个 value- S1topologyKey: topology.kubernetes.io/zonepodAntiAffinity: # pod 反亲和力配置preferredDuringSchedulingIgnoredDuringExecution: # 尽量不要将当前节点部署到匹配下列参数的 pod 所在的 node 上- weight: 100 # 权重podAffinityTerm: # pod 亲和力配置条件labelSelector: # 标签选择器matchExpressions: # 匹配表达式- key: security # 匹配的 keyoperator: In # 匹配的方式values:- S2 # 匹配的 valuetopologyKey: topology.kubernetes.io/zonecontainers:- name: with-pod-affinityimage: pause:2.0

 

http://www.lryc.cn/news/112373.html

相关文章:

  • 【数据结构】实现单链表的增删查
  • Vue2 第二十节 vue-router (四)
  • 第三章 图论 No.1单源最短路及其综合应用
  • ❤ npm不是内部或外部命令,也不是可运行的程序 或批处理文件
  • 关于Godot游戏引擎制作流水灯
  • C语言 函数指针详解
  • LNMP及论坛搭建
  • 【使用机器学习和深度学习对城市声音进行分类】基于两种技术(ML和DL)对音频数据(城市声音)进行分类(Matlab代码实现)
  • Godot 4 练习 - 制作粒子
  • Java基础继承详解
  • 如何维护你的电脑:打造IT人的重要武器
  • 【雕爷学编程】MicroPython动手做(31)——物联网之Easy IoT 3
  • Elasticsearch 快照和恢复
  • Packet Tracer - 检验 IPv4 和 IPv6 编址
  • PHP8的表达式-PHP8知识详解
  • 亚马逊云科技七项生成式AI新产品生成式AI,为用户解决数据滞后等难题
  • 图片等比例显示全部,兼容不同宽高比例图片
  • ·[K8S:使用calico网络插件]:解决集群节点NotReady问题
  • 泊松损坏图像的快速尺度间小波去噪研究(Matlab代码实现)
  • 服务器端开发-golang dlv 远程调试
  • STM32F103——时钟配置
  • 【Linux】信号捕捉
  • 超详情的开源知识库管理系统- mm-wiki的安装和使用
  • 安卓:UDP通信
  • clickhouse安装
  • Cpp学习——string(2)
  • python进阶编程
  • 算法练习--leetcode 链表
  • Android性能优化—Apk瘦身优化
  • 前端主题切换方案——CSS变量