Kubernetes(k8s):深入理解k8s中的亲和性(Affinity)及其在集群调度中的应用

news2024/10/6 2:24:02

Kubernetes(k8s):深入理解k8s中的亲和性(Affinity)及其在集群调度中的应用

  • 1、什么是亲和性?
  • 2、节点亲和性(Node Affinity)
    • 2.1 硬性节点亲和性规则(required)
    • 2.2 软性节点亲和性规则(preferred)
  • 3、Pod亲和性(Pod Affinity)
    • 3.1 Pod硬性亲和性规则
    • 3.2 Pod软性亲和性规则
  • 4、Pod 反亲和性(Pod Anti-Affinity)
  • 5、总结


💖The Begin💖点点关注,收藏不迷路💖

在 Kubernetes(K8s)集群中,亲和性(Affinity)是一项强大的功能,它允许我们通过标签选择器来指定 Pod 与节点或其他 Pod 之间的关系,以影响调度决策。

在这篇博客中,我们将深入探讨 Kubernetes 中的亲和性概念、不同类型的亲和性以及它们在集群调度中的应用。

1、什么是亲和性?

在Kubernetes中,亲和性是一种调度策略,用于指定Pod倾向于被调度到具有特定属性的节点。亲和性分为两种类型:

1、节点亲和性(Node Affinity):指定Pod倾向于被调度到具有特定标签或标签表达式的节点。
2、Pod亲和性(Pod Affinity):指定Pod倾向于与具有特定标签或标签表达式的其他Pod共存。

2、节点亲和性(Node Affinity)

节点亲和性允许我们指定 Pod 应该在哪些节点上运行。它可以根据节点的标签来决定 Pod 的调度位置。

节点亲和性规则可以是硬性的或软性的。硬性规则要求 Pod 必须在匹配的节点上运行,而软性规则则更加宽松,只是倾向于将 Pod 调度到符合条件的节点上。

2.1 硬性节点亲和性规则(required)

1、硬性规则指定了 Pod 必须被调度到满足规则条件的节点上,否则 Pod 将无法被调度和启动。

例如,可以使用硬性节点亲和性规则来确保 Pod 只能被调度到拥有特定标签的节点上。这在需要确保特定类型的节点才能运行某些任务时非常有用。

下面是一个示例 YAML 文件,其中定义了一个 Pod,并指定了硬性节点亲和性规则,要求 Pod 只能被调度到具有标签为 “gpu=true” 的节点上:

apiVersion: v1
kind: Pod
metadata:
  name: nginx-pod  # 定义 Pod 的名称为 "nginx-pod"
spec:
  containers:
  - name: nginx-container  # 定义 Pod 中的容器名称为 "nginx-container"
    image: nginx:latest  # 使用最新版本的 nginx 容器镜像
  affinity:
    nodeAffinity:  # 指定节点亲和性规则
      requiredDuringSchedulingIgnoredDuringExecution:  # 硬性节点亲和性规则,要求在调度过程中必须满足条件
        nodeSelectorTerms:  # 指定节点选择条件
        - matchExpressions:  # 指定匹配表达式
          - key: gpu  # 定义匹配表达式的键为 "gpu"
            operator: In  # 使用 In 操作符进行匹配
            values:  # 定义匹配的值
            - "true"  # 要求节点的标签中包含值为 "true" 的 "gpu" 标签

2.2 软性节点亲和性规则(preferred)

软性规则指定了 Pod 更倾向于被调度到满足规则条件的节点上,但并不强制要求。

例如,可以使用软性节点亲和性规则来指定 Pod 更倾向于被调度到某个特定区域的节点上,以减少数据传输延迟。

下面是一个示例 YAML 文件,其中定义了一个 Pod,并指定了软性节点亲和性规则,要求 Pod 更倾向于被调度到具有标签为 “zone=us-west” 的节点上:

apiVersion: v1
kind: Pod
metadata:
  name: nginx-pod  # Pod的名称
spec:
  containers:
  - name: nginx-container  # 容器的名称
    image: nginx-image  # 容器使用的镜像
  affinity:
    nodeAffinity:  # 节点亲和性
      preferredDuringSchedulingIgnoredDuringExecution:  # 在调度期间优先考虑,但在执行期间被忽略
      - weight: 1  # 权重为1,表示较高的优先级
        preference:  # 优先选择的条件
          matchExpressions:  # 匹配表达式列表
          - key: zone  # 标签的键
            operator: In  # 匹配操作符,表示在值列表中的任何一个
            values:
            - "us-west"  # 匹配的值为"us-west"

3、Pod亲和性(Pod Affinity)

Pod 亲和性允许我们指定 Pod 应该与哪些其他 Pod 共同运行。它可以确保相关的服务或组件在同一节点或不同节点上运行,以提高性能或可用性。与节点亲和性类似,Pod 亲和性规则也可以是硬性的或软性的。

3.1 Pod硬性亲和性规则

硬性亲和性规则指定了 Pod 必须满足的条件,如果这些条件不能满足,Pod 将不会被调度到任何节点上。

以下是一个使用硬性亲和性规则的示例,要求 Pod 只能被调度到具有 “zone=us-west” 和 “environment=production” 标签的节点上:

apiVersion: v1  # 指定 Kubernetes API 版本
kind: Pod  # 定义资源类型为 Pod
metadata:
  name: affinity-pod  # 指定 Pod 的名称为 affinity-pod
spec:
  containers:
  - name: affinity-container  # 定义 Pod 中的容器名称为 affinity-container
    image: affinity-image  # 指定容器所使用的镜像为 affinity-image
  affinity:  # 定义 Pod 的亲和性规则
    nodeAffinity:  # 指定节点亲和性规则
      requiredDuringSchedulingIgnoredDuringExecution:  # 指定为硬性节点亲和性规则
        nodeSelectorTerms:  # 指定节点选择器条件
        - matchExpressions:  # 指定匹配表达式
          - key: zone  # 指定节点标签的键为 zone
            operator: In  # 指定匹配操作符为 In
            values:  # 指定匹配的值
            - us-west  # 匹配值为 us-west
          - key: environment  # 指定节点标签的键为 environment
            operator: In  # 指定匹配操作符为 In
            values:  # 指定匹配的值
            - production  # 匹配值为 production

3.2 Pod软性亲和性规则

软性亲和性规则指定了 Pod 偏好的条件,如果这些条件可以满足,Pod 将会优先被调度到符合条件的节点上,但如果无法满足,Pod 仍然可以被调度到其他节点上。

以下是一个使用软性亲和性规则的示例,要求 Pod 偏好被调度到具有 “zone=us-east” 或 “zone=us-west” 标签的节点上:

apiVersion: v1  # 指定 Kubernetes API 版本
kind: Pod  # 定义资源类型为 Pod
metadata:
  name: affinity-pod  # 指定 Pod 的名称为 affinity-pod
spec:
  containers:
  - name: affinity-container  # 定义 Pod 中的容器名称为 affinity-container
    image: affinity-image  # 指定容器所使用的镜像为 affinity-image
  affinity:  # 定义 Pod 的亲和性规则
    nodeAffinity:  # 指定节点亲和性规则
      preferredDuringSchedulingIgnoredDuringExecution:  # 指定为软性节点亲和性规则
      - weight: 1  # 指定权重为 1
        preference:  # 指定偏好条件
          matchExpressions:  # 指定匹配表达式
          - key: zone  # 指定节点标签的键为 zone
            operator: In  # 指定匹配操作符为 In
            values:  # 指定匹配的值
            - us-east  # 匹配值为 us-east
      - weight: 1  # 指定权重为 1
        preference:  # 指定偏好条件
          matchExpressions:  # 指定匹配表达式
          - key: zone  # 指定节点标签的键为 zone
            operator: In  # 指定匹配操作符为 In
            values:  # 指定匹配的值
            - us-west  # 匹配值为 us-west

4、Pod 反亲和性(Pod Anti-Affinity)

Pod 反亲和性(Pod Anti-Affinity)是一种 Kubernetes 调度策略,用于指定 Pod 不能被调度到与其他特定 Pod 相同的节点上。这有助于提高应用程序的可靠性和可用性,避免将相互依赖或相互竞争的 Pod 部署在同一节点上。

以下是一个 Pod 反亲和性的示例 :

要求该 Pod 不能被调度到具有标签 app=my-app 的其他 Pod 所在的节点上。这样可以确保这两个相互关联的 Pod 不会被部署在同一节点上,从而提高应用程序的可靠性。

apiVersion: v1  # 指定 Kubernetes API 版本
kind: Pod  # 定义资源类型为 Pod
metadata:
  name: anti-affinity-pod  # 指定 Pod 的名称为 anti-affinity-pod
spec:
  containers:
  - name: anti-affinity-container  # 定义 Pod 中的容器名称为 anti-affinity-container
    image: anti-affinity-image  # 指定容器所使用的镜像为 anti-affinity-image
  affinity:  # 定义 Pod 的亲和性规则
    podAntiAffinity:  # 指定 Pod 反亲和性规则
      requiredDuringSchedulingIgnoredDuringExecution:  # 指定为硬性 Pod 反亲和性规则
      - labelSelector:  # 指定标签选择器
          matchExpressions:  # 指定匹配表达式
          - key: app  # 指定标签的键为 app
            operator: In  # 指定匹配操作符为 In
            values:  # 指定匹配的值
            - my-app  # 匹配值为 my-app

5、总结

在这里插入图片描述

在这里插入图片描述


💖The End💖点点关注,收藏不迷路💖

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1590150.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

TCP/IP协议—UDP

TCP/IP协议—UDP UDP协议UDP通信特点 UDP头部报文UDP检验 UDP协议 用户数据传输协议 (UDP,User Datagram Protocol) 是一种无连接的协议,提供了简单的数据传输服务,不保证数据的顺序以及完整性。应用层很多通信协议都基于UDP进行传输&#x…

「51媒体网」汽车类媒体有哪些?车展媒体宣传

传媒如春雨,润物细无声,大家好,我是51媒体网胡老师。 汽车类媒体有很多,具体如下: 汽车之家:提供全面的汽车新闻、评测、导购等内容。 爱卡汽车:同样是一个综合性的汽车信息平台,涵…

iPad 无法解锁?修复 iPad 滑动解锁不起作用的 9 个解决方案

“我的 iPad Pro 一整天都工作正常,直到 20 分钟前。当我解锁它时,它不让我向上滑动。屏幕有响应,但我的 iPad 无法解锁。是否有其他人遇到过这种情况并找到了解决方法?解决方案?” ——来自 Apple 支持社区 iPad 屏幕…

华媒舍:7种方式,打造出旅游媒体套餐

现如今,伴随着旅游业发展与繁荣,更多旅游业发展从业人员越来越重视产品营销品牌基本建设,希望可以将自己的度假旅游产品和服务营销推广给更多的潜在用户。而建立一个优秀的旅游业发展媒体套餐内容品牌是吸引目标客户的重要步骤。下面我们就详…

Harmony鸿蒙南向驱动开发-SPI接口使用

功能简介 SPI指串行外设接口(Serial Peripheral Interface),是一种高速的,全双工,同步的通信总线。SPI是由Motorola公司开发,用于在主设备和从设备之间进行通信。 SPI接口定义了操作SPI设备的通用方法集合…

2024比特币减半,Web3的“1995时刻”即将到来

随着比特币减半的到来,加密货币市场迎来了一个关键的转折点。2024年的比特币减半不仅是对比特币供应和挖矿激励的一次重大调整,更是对整个Web3应用领域产生深远影响的事件。 首先,比特币减半的事件本身就为市场带来了一种稀缺性的概念&#…

半透明进口特氟龙材质镊子可耐受强酸强碱腐蚀PFA镊子

PFA镊子用于夹取小型片状、薄状、块状样品,广泛应用在半导体、新材料、新能源、原子能、石油化工、无线电、电力机械等行业。 具有耐高低温性(可使用温度-200℃~+260℃)、耐腐蚀、表面不粘性等特点,用于苛…

代码随想录算法训练营Day53|LC1143 最长公共子序列LC1035 不相交的线LC53 最大子数组和

一句话总结:秒了。 原题链接:1143 最长公共子序列 与昨天的最长重复子数组极度类似。 由于这里是子序列,两者不相等时有dp[i][j] Math.max(dp[i][j - 1], dp[i - 1][j])。同时由于子序列的缘故,dp数组及下标的含义也有了改变&am…

GPDB技术内幕 - SEMI JOIN浅析

GPDB技术内幕 - SEMI JOIN浅析 SEMI JOIN顾名思义,半连接,相对于join字段来说,针对外表的一行记录,内表只要有一条满足,就输出外表记录。注意,这里是仅输出外表记录。GPDB中有几种实现方式,本文…

一篇实操vitrualbox虚拟机根目录扩容(详细,实操陈功)

一篇实操vitrualbox虚拟机根目录扩容(详细,实操陈功) 创建虚拟介质 第一步、 第二步、 第三步、一直下一步,直到下面的页面 分配空间到更目录下 第一步、 第二步、查看创建的物理磁盘 lsblk第三步、查看原本磁盘可用空间 df …

ARL资产侦察灯塔系统

1、资产侦察灯塔系统搭建 1.1、系统要求 目前暂不支持 Windows,Linux 和 MAC 建议采用 Docker 运行,系统配置最低 2 核 4G。 由于自动资产发现过程中会有大量的的发包,建议采用云服务器可以带来更好的体验 实验环境: 系统&…

新版网络安全等级保护定级指南解读

网络安全等级保护工作的作用对象,主要包括基础信息网络、工业控制系统、云计算平台、物联网、使用移动互联技术的网络和大数据等。 软件开发全套资料获取进主页或者本文末个人名片直接获取。

uniapp 编译后分包下静态图片404问题解决方案

如上图官方说明&#xff1a; 在分包下建立一个static文件夹即可&#xff1a; 分包内代码引用图片 <image src"/分包名称/img/图片名称"></image> <image src"/dataView/img/图片名称"></image>

目标检测——微藻检测数据集

一、重要性及意义 微藻识别检测的重要性及意义主要体现在以下几个方面&#xff1a; 首先&#xff0c;微藻作为自然界光合作用的主体&#xff0c;在地球的太阳能固定以及碳循环中起到非常重要的作用。因此&#xff0c;对微藻的识别检测有助于我们更深入地理解地球生态系统的运…

基于FMC接口的Kintex-7 XC7K325T PCIeX4 3U PXIe接口卡

基于FMC接口的Kintex-7 XC7K325T PCIeX4 3U PXIe接口卡 一、板卡概述 本板卡基于Xilinx公司的FPGAXC7K325T-2FFG900 芯片&#xff0c;pin_to_pin兼容FPGAXC7K410T-2FFG900 &#xff0c;支持PCIeX8、64bit DDR3容量2GByte&#xff0c;HPC的FMC连接器&#xff0c;板卡支持PXI…

一文了解HTTPS的加密原理

HTTPS是一种安全的网络通信协议&#xff0c;用于在互联网上提供端到端的加密通信&#xff0c;确保数据在客户端&#xff08;如Web浏览器&#xff09;与服务器之间传输时的机密性、完整性和身份验证。HTTPS的加密原理主要基于SSL/TLS协议&#xff0c;以下详细阐述其工作过程&…

2024 年适用于 Mac 电脑的最佳 SD 卡恢复软件

D 卡体积很小&#xff0c;广泛用于数码相机、摄像机、行车记录仪、无人机等。通常&#xff0c;在使用设备拍照、拍摄视频后&#xff0c;您会将文件移动到 Mac 进行进一步编辑或作为备份。大多数时候&#xff0c;应该存在问题。但是&#xff0c;您的 SD 卡仍然会出现一些问题并导…

银行司库系统应用架构介绍

继国务院国资委印发了《关于推动中央企业加快司库体系建设进一步加强资金管理的意见》以及《关于中央企业加快建设世界一流财务管理体系的指导意见》&#xff0c;司库体系建设开始得到了更多重视。其中&#xff0c;作为改革风向标&#xff0c;央企数字化转型及司库建设对整个行…

如何使用 Grafana 监控文件系统状态

当 JuiceFS 文件系统部署完成并投入生产环境&#xff0c;接下来就需要着手解决一个非常重要的问题 —— 如何实时监控它的运行状态&#xff1f;毕竟&#xff0c;它可能正在为关键的业务应用或容器工作负载提供持久化存储支持&#xff0c;任何小小的故障或性能下降都可能造成不利…

【c++leetcode】14. Longest Common Prefix

问题入口 解决方案 class Solution { public:string longestCommonPrefix(vector<string>& v) {string ans "";sort(v.begin(), v.end());int n v.size();string first v[0],last v[n - 1];for(int i 0; i < min(first.size(),last.size()); i){…