k8s亲和力和非亲和力

在 Kubernetes 中,亲和力(Affinity)和非亲和力(Anti-Affinity)是用于控制 Pod 调度策略的机制,它们可以帮助优化资源利用率、提高应用性能和可用性。以下是亲和力和非亲和力的详细解释:

亲和力(Affinity)
亲和力允许用户定义规则,指定 Pod 应该被调度到哪些节点上。亲和力分为两种类型:
节点亲和力(Node Affinity)
定义:节点亲和力允许用户通过节点的标签来指定 Pod 应该被调度到哪些节点上。

作用:可以提高资源利用率、优化性能。
Node亲和力允许你指定Pod应该被调度到具有特定标签的节点上。它分为两种类型:
requiredDuringSchedulingIgnoredDuringExecution:必须满足的规则,否则Pod不会被调度。
preferredDuringSchedulingIgnoredDuringExecution:尽力满足的规则,但不是必须的。
示例:

affinity:nodeAffinity:requiredDuringSchedulingIgnoredDuringExecution:nodeSelectorTerms:- matchExpressions:- key: coloroperator: Invalues:- blue- green

这个例子表示 Pod 只会被调度到标签为 color=blue 或 color=green 的节点上。

Pod 亲和力(Pod Affinity)
定义:Pod 亲和力允许用户通过其他 Pod 的标签来指定 Pod 应该被调度到哪些节点上。

作用:可以确保相关 Pod 被调度到同一节点或相近的节点上,从而减少网络延迟。
Pod亲和力允许你指定Pod应该与其他具有特定标签的Pod共同部署在同一个节点上。它同样分为两种类型:
requiredDuringSchedulingIgnoredDuringExecution:必须满足的规则。
preferredDuringSchedulingIgnoredDuringExecution:尽力满足的规则。
示例:

affinity:podAffinity:requiredDuringSchedulingIgnoredDuringExecution:- labelSelector:matchExpressions:- key: appoperator: Invalues:- webtopologyKey: kubernetes.io/hostname

这个例子表示 Pod 只会被调度到已经运行了标签为 app=web 的其他 Pod 的节点上。

详细解释
1.affinity
含义:定义 Pod 的亲和力和非亲和力策略。
作用:用于控制 Pod 的调度行为,确保 Pod 被调度到满足特定条件的节点上。
2. podAffinity
含义:定义 Pod 的亲和力策略。
作用:确保 Pod 与某些其他 Pod 调度到同一节点或相近的节点上。
3. requiredDuringSchedulingIgnoredDuringExecution
含义:表示这个亲和力规则在调度期间是必须满足的,但在执行期间可能会被忽略。
作用:确保在调度时,Pod 只会被调度到满足条件的节点上。如果节点上的条件在运行时发生变化,这个规则可能会被忽略。
4. labelSelector
含义:定义标签选择器,用于选择其他 Pod。
作用:通过标签选择器,指定哪些 Pod 是我们关心的。
5. matchExpressions
含义:定义匹配表达式,用于选择满足特定条件的 Pod。
作用:通过匹配表达式,指定哪些 Pod 是我们想要与当前 Pod 调度到同一节点上的。
6. key 和 operator
key:标签的键。
operator:匹配操作符,可以是 In、NotIn、Exists、DoesNotExist 等。
values:标签的值列表。
7. topologyKey
含义:定义拓扑域的键。
作用:指定在哪个拓扑域内应用亲和力策略。常见的拓扑键包括:
kubernetes.io/hostname:表示节点的主机名。
failure-domain.beta.kubernetes.io/zone:表示可用区。
failure-domain.beta.kubernetes.io/region:表示区域。

非亲和力(Anti-Affinity)
非亲和力允许用户定义规则,指定 Pod 不应该被调度到哪些节点上。非亲和力也分为两种类型:
节点非亲和力(Node Anti-Affinity)
定义:节点非亲和力允许用户通过节点的标签来指定 Pod 不应该被调度到哪些节点上。

作用:可以提高容错性、确保资源隔离。
Node亲和力允许你指定Pod应该被调度到具有特定标签的节点上。它分为两种类型:
requiredDuringSchedulingIgnoredDuringExecution:必须满足的规则,否则Pod不会被调度。
preferredDuringSchedulingIgnoredDuringExecution:尽力满足的规则,但不是必须的。
示例:

affinity:nodeAffinity:requiredDuringSchedulingIgnoredDuringExecution:nodeSelectorTerms:- matchExpressions:- key: coloroperator: NotInvalues:- yellow

这个例子表示 Pod 不会被调度到标签为 color=yellow 的节点上。

Pod 非亲和力(Pod Anti-Affinity)
定义:Pod 非亲和力允许用户通过其他 Pod 的标签来指定 Pod 不应该被调度到哪些节点上。

作用:可以确保相关 Pod 不被调度到同一节点或相近的节点上,从而提高可用性。
Pod亲和力允许你指定Pod应该与其他具有特定标签的Pod共同部署在同一个节点上。它同样分为两种类型:
requiredDuringSchedulingIgnoredDuringExecution:必须满足的规则。
preferredDuringSchedulingIgnoredDuringExecution:尽力满足的规则。
示例:

affinity:	podAntiAffinity:	requiredDuringSchedulingIgnoredDuringExecution:- labelSelector:matchExpressions:- key: appoperator: Invalues:- dbtopologyKey: kubernetes.io/hostname

这个例子表示 Pod 不会被调度到已经运行了标签为 app=db 的其他 Pod 的节点上。
详细解释
1.affinity
含义:定义 Pod 的亲和力和非亲和力策略。
作用:用于控制 Pod 的调度行为,确保 Pod 被调度到满足特定条件的节点上,或者避免被调度到某些节点上。
2.podAntiAffinity
含义:定义 Pod 的非亲和力策略。
作用:确保 Pod 不与某些其他 Pod 调度到同一节点或相近的节点上。
3.requiredDuringSchedulingIgnoredDuringExecution
含义:表示这个非亲和力规则在调度期间是必须满足的,但在执行期间可能会被忽略。
作用:确保在调度时,Pod 不会被调度到不符合条件的节点上。如果节点上的条件在运行时发生变化,这个规则可能会被忽略。
4.labelSelector
含义:定义标签选择器,用于选择其他 Pod。
作用:通过标签选择器,指定哪些 Pod 是我们关心的。
5.matchExpressions
含义:定义匹配表达式,用于选择满足特定条件的 Pod。
作用:通过匹配表达式,指定哪些 Pod 是我们想要避免与当前 Pod 调度到同一节点上的。
6.key 和 operator
key:标签的键。
operator:匹配操作符,可以是 In、NotIn、Exists、DoesNotExist 等。
values:标签的值列表。
7.topologyKey
含义:定义拓扑域的键。
作用:指定在哪个拓扑域内应用非亲和力策略。常见的拓扑键包括:
kubernetes.io/hostname:表示节点的主机名。
failure-domain.beta.kubernetes.io/zone:表示可用区。
failure-domain.beta.kubernetes.io/region:表示区域。

查看亲和力设置
要查看Pod的亲和力设置,可以使用kubectl describe pod 命令。这将显示Pod的详细信息,包括其亲和力规则。

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

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

相关文章

开发一款游戏需要哪些岗位角色参与?

常见分类 1. 游戏策划(Game Designer) 核心职责:设计游戏的玩法、规则、内容和整体体验。 具体工作: 系统设计:设计游戏的战斗、经济、成长、社交等核心系统。 数值设计:平衡角色属性、装备数值、经济系…

Asp.NET Core WebApi 创建带鉴权机制的Api

构建一个包含 JWT(JSON Web Token)鉴权的 Web API 是一种常见的做法,用于保护 API 端点并验证用户身份。以下是一个基于 ASP.NET Core 的完整示例,展示如何实现 JWT 鉴权。 1. 创建 ASP.NET Core Web API 项目 使用 .NET CLI 或 …

Jenkins 发送钉钉消息

这里不介绍 Jenkins 的安装,可以网上找到很多安装教程,重点介绍如何集成钉钉消息。 需要提前准备钉钉机器人的 webhook 地址。(网上找下,很多教程) 下面开始配置钉钉机器人,登录 Jenkins,下载 …

CentOS中离线安装DockerCompos并用其部署Rabbitmq(使用离线导入导出docker镜像方式)

场景 DockerDockerCompose实现部署jenkins,并实现jenkinsfile打包SpringBootVue流水线项目过程详解、踩坑记录(附镜像资源、离线包资源下载): DockerDockerCompose实现部署jenkins,并实现jenkinsfile打包SpringBootVue流水线项目过程详解、踩坑记录(附镜像资源、离…

stm32week11

stm32学习 八.stm32基础 2.stm32内核和芯片 F1系统架构:4个主动单元和4个被动单元 AHB是内核高性能总线,APB是外围总线 总线矩阵将总线和各个主动被动单元连到一起 ICode总线直接连接Flash接口,不需要经过总线矩阵 AHB:72MHz&am…

贪心算法:部分背包问题深度解析

简介: 该Java代码基于贪心算法实现了分数背包问题的求解,核心通过单位价值降序排序和分阶段装入策略实现最优解。首先对Product数组执行双重循环冒泡排序,按wm(价值/重量比)从高到低重新排列物品;随后分两阶段装入:循环…

13. Langchain异步处理:提升应用性能的关键技巧

引言:从"顺序等待"到"并行加速" 2025年某电商平台引入LangChain异步处理后,大促期间订单处理能力提升5倍,系统响应延迟降低70%。本文将基于LangChain的异步架构,详解如何通过并行执行流式处理,让…

ros2-rviz2控制unity仿真的6关节机械臂,探索从仿真到实际应用的过程

文章目录 前言(Introduction)搭建开发环境(Setup Development Environment)在window中安装Unity(Install Unity in window)创建Docker容器,并安装相关软件(Create Docker containers…

计算机组成原理笔记(十四)——3.4指令类型

一台计算机的指令系统可以有上百条指令,这些指令按其功能可以分成几种类型,下面分别介绍。 3.4.1数据传送类指令 一、核心概念与功能定位 数据传送类指令是计算机指令系统中最基础的指令类型,负责在 寄存器、主存、I/O设备 之间高效复制数…

各开源协议一览

在 GitHub 上,开源项目通常会使用一些常见的开源协议来定义项目的使用、修改和分发规则。以下是目前 GitHub 上最常见的几种开源协议及其差异和示例说明: TL;DR 协议宽松程度是否强制开源专利保护适用场景MIT最宽松否无希望代码被广泛使用Apache 2.0宽松…

51c自动驾驶~合集17

我自己的原文哦~ https://blog.51cto.com/whaosoft/13793157 #汇聚感知、定位、规划控制的自动驾驶系统 自动驾驶技术在应用到车辆上之后可以通过提高吞吐量来缓解道路拥堵,通过消除人为错误来提高道路安全性,并减轻驾驶员的驾驶负担,从…

小程序开发指南

小程序开发指南 目录 1. 小程序开发概述 1.1 什么是小程序1.2 小程序的优势1.3 小程序的发展历程 2. 开发准备工作 2.1 选择开发平台2.2 开发环境搭建2.3 开发模式选择 3. 小程序开发流程 3.1 项目规划3.2 界面设计3.3 代码开发3.4 基本开发示例3.5 数据存储3.6 网络请求3.7 …

Day15:关于MySQL的编程技术——基础知识

前言:先创建一个练习的数据库和数据 1.创建数据库并创建数据表的基本结构 -- 创建练习数据库 CREATE DATABASE db_programming; USE db_programming;-- 创建员工表(包含各种数据类型) CREATE TABLE employees (emp_id INT PRIMARY KEY AUTO…

批处理脚本bat丨遍历一个包含项目名称的数组,并对每个文件中的项目执行 git pull 操作 (一键拉很多文件的代码)

文章目录 前言一、操作方式二、文件展示三、分析代码结构四、代码五、需要注意的潜在问题六、改进后的代码七、改进说明八、感谢 前言 由于之前git服务部署在本地服务器,处于代码安全角度考虑。领导让我将所有的项目代码手动物理备份一份并且发给他。 这种傻傻的操…

【C++】C与C++、C++内存空间、堆与栈

C嘎嘎嘎嘎嘎~ C与C的区别与联系 C内存空间 int global_var; // 未初始化全局变量,BSS段 const char* str "Hello"; // 字符串常量text段 in数据段void func() {static int static_var; // 未初始化的静态变量,数据段int local_var; …

舵机:机器人领域的“关节革命者”

机器人的技术,每一个细微的进步都可能引领一场行业变革。而在这场变革中,舵机作为机器人关节的核心部件,正悄然上演着一场革命性的应用风暴。从简单的关节运动到复杂的姿态控制,舵机以其卓越的性能和无限的可能,重新定…

微前端的不断探索之路—— qiankun 实战与思考!

全文目录: 开篇语📝 前言🛠️ 微前端是什么?为什么需要它?💡 先从“前端痛点”说起🧐 微前端的优势 🤹‍♀️ qiankun 简介与核心概念🌟 为什么选择 qiankun?…

拆解加密黑盒

在Web安全与数据爬取领域,JavaScript加密黑盒的逆向工程是核心技术之一。本文基于行业通用方法论与实战案例,提炼出一套标准化的五步逆向流程,涵盖目标定位、代码提取、逻辑分析、算法复现到自动化集成的全链路解决方案,帮助开发者…

IntelliJ IDEA 中安装和使用通义灵码 AI 编程助手教程

随着人工智能技术的发展,AI 编程助手逐渐成为提升开发效率的强大工具。通义灵码是阿里云推出的一款 AI 编程助手,它能够帮助开发者实现智能代码补全、代码解释、生成单元测试等功能,极大地提升了编程效率和代码质量。 IntelliJ IDEA 是一款广…

Redis 特性和应用场景

1. Redis特性 1)In-memory data structures Redis 在内存中存储数据,key 是 String, value 可以是 hash, list, set, sorted set, stream ... MySQL主要是通过 “表” 的方式来存储组织数据的 “关系型数据库” Redis主要是通过 “键值对”…