在 Kubernetes 中设置 Pod 优先级及其调度策略详解

个人名片
在这里插入图片描述
🎓作者简介:java领域优质创作者
🌐个人主页:码农阿豪
📞工作室:新空间代码工作室(提供各种软件服务)
💌个人邮箱:[2435024119@qq.com]
📱个人微信:15279484656
🌐个人导航网站:www.forff.top
💡座右铭:总有人要赢。为什么不能是我呢?

  • 专栏导航:

码农阿豪系列专栏导航
面试专栏:收集了java相关高频面试题,面试实战总结🍻🎉🖥️
Spring5系列专栏:整理了Spring5重要知识点与实战演练,有案例可直接使用🚀🔧💻
Redis专栏:Redis从零到一学习分享,经验总结,案例实战💐📝💡
全栈系列专栏:海纳百川有容乃大,可能你想要的东西里面都有🤸🌱🚀

目录

  • 在 Kubernetes 中设置 Pod 优先级及其调度策略详解
    • 一、设置 Pod 优先级
      • 1. 创建 PriorityClass 对象
      • 2. 在 Pod 配置中使用 PriorityClass
    • 二、Pod 的调度策略
      • 1. 调度器按优先级排序悬决 Pod
      • 2. 触发抢占逻辑
        • 抢占逻辑的详细过程:
      • 3. Pod 的抢占策略与 Pod 间亲和性冲突
        • 亲和性冲突的详细情景:
      • 4. 示例:高优先级 Pod 的调度和抢占
        • 步骤 1:创建一个低优先级的 PriorityClass
        • 步骤 2:创建一个低优先级的 Pod
        • 步骤 3:创建一个高优先级的 Pod
      • 5. 验证抢占行为
    • 三、实际应用中的注意事项
      • 1. 资源规划
      • 2. 监控和告警
      • 3. 综合考虑调度策略
      • 4. 测试和优化
    • 四、总结

在 Kubernetes 中设置 Pod 优先级及其调度策略详解

在 Kubernetes 集群中,Pod 的优先级和抢占机制是调度 Pod 的关键策略之一。通过设置不同的优先级,我们可以确保重要的 Pod 优先获得调度资源,保证关键应用的稳定运行。本文将详细介绍如何设置 Pod 优先级及其调度策略和抢占逻辑,并探讨其在实际应用中的具体操作和注意事项。

一、设置 Pod 优先级

1. 创建 PriorityClass 对象

首先,需要创建一个 PriorityClass 对象。PriorityClass 用于定义 Pod 的优先级,数值越高优先级越高。

下面是一个示例,展示如何定义一个高优先级的 PriorityClass

apiVersion: scheduling.k8s.io/v1
kind: PriorityClass
metadata:name: high-priority
value: 1000
globalDefault: false
description: "This priority class is for high priority pods."

在这个配置中:

  • name 定义了优先级类的名称。
  • value 是优先级的数值,值越高,优先级越高。
  • globalDefault 表示是否将此优先级类设置为默认优先级。
  • description 是对该优先级类的描述。

应用这个 PriorityClass 配置文件:

kubectl apply -f high-priority.yaml

2. 在 Pod 配置中使用 PriorityClass

创建一个 Pod,并在其配置中引用上面定义的 PriorityClass

apiVersion: v1
kind: Pod
metadata:name: high-priority-pod
spec:containers:- name: nginximage: nginxpriorityClassName: high-priority

在这个示例中,我们创建了一个名为 high-priority-pod 的 Pod,并设置其 priorityClassNamehigh-priority,这意味着该 Pod 的优先级为 1000。

二、Pod 的调度策略

1. 调度器按优先级排序悬决 Pod

Kubernetes 调度器在调度 Pod 时,会按优先级对悬决(Pending)Pod 进行排序。高优先级的 Pod 会比低优先级的 Pod 更早被调度。

例如,如果有两个悬决 Pod,一个优先级为 1000,另一个优先级为 500,调度器会优先尝试调度优先级为 1000 的 Pod。

2. 触发抢占逻辑

当调度器尝试调度一个高优先级 Pod 时,如果集群中没有满足其要求的节点,调度器会触发抢占逻辑。抢占逻辑会在当前节点中驱逐一个或多个低优先级的 Pod,以腾出资源调度高优先级的 Pod。

抢占逻辑的详细过程:
  1. 确定高优先级 Pod 的资源需求:调度器首先会确定高优先级 Pod 需要的资源(如 CPU 和内存)。
  2. 检查节点资源:调度器会检查每个节点,看看是否有满足高优先级 Pod 需求的可用资源。
  3. 触发抢占:如果没有节点满足要求,调度器会在节点中寻找低优先级的 Pod,并将其驱逐,以腾出资源。
  4. 调度高优先级 Pod:在腾出资源后,调度器会将高优先级 Pod 调度到该节点上。

3. Pod 的抢占策略与 Pod 间亲和性冲突

在某些情况下,高优先级 Pod 需要抢占低优先级 Pod,但这可能与 Pod 间的亲和性策略发生冲突。下面我们来探讨这种情况及其解决方案。

亲和性冲突的详细情景:
  1. 高优先级 Pod 未找到合适的调度节点:假设一个高优先级的 Pod 未能找到满足其资源需求的调度节点。
  2. 需要抢占低优先级 Pod:调度器决定需要驱逐一个低优先级的 Pod,以腾出资源。
  3. 亲和性冲突:高优先级 Pod 与当前节点上的其他 Pod 具有亲和性要求。例如,高优先级 Pod 需要与某些特定的 Pod 同在一个节点上。

如果驱逐低优先级 Pod 会导致亲和性原则被破坏,那么高优先级 Pod 依然无法被调度。在这种情况下,Kubernetes 调度器不会尝试抢占节点上的任何 Pod,而是会寻找其他节点来满足调度需求。

4. 示例:高优先级 Pod 的调度和抢占

为了更好地理解调度和抢占逻辑,我们来看一个详细的示例。

步骤 1:创建一个低优先级的 PriorityClass

首先,我们创建一个低优先级的 PriorityClass:

apiVersion: scheduling.k8s.io/v1
kind: PriorityClass
metadata:name: low-priority
value: 500
globalDefault: false
description: "This priority class is for low priority pods."

应用这个配置文件:

kubectl apply -f low-priority.yaml
步骤 2:创建一个低优先级的 Pod

接下来,创建一个低优先级的 Pod:

apiVersion: v1
kind: Pod
metadata:name: low-priority-pod
spec:containers:- name: busyboximage: busyboxcommand: ["sh", "-c", "sleep 3600"]priorityClassName: low-priority

应用这个配置文件:

kubectl apply -f low-priority-pod.yaml
步骤 3:创建一个高优先级的 Pod

然后,创建一个高优先级的 Pod:

apiVersion: v1
kind: Pod
metadata:name: high-priority-pod
spec:containers:- name: nginximage: nginxpriorityClassName: high-priority

应用这个配置文件:

kubectl apply -f high-priority-pod.yaml

5. 验证抢占行为

当高优先级 Pod high-priority-pod 被调度时,调度器会检查节点资源。如果没有足够的资源,调度器会触发抢占逻辑,将低优先级 Pod low-priority-pod 驱逐,以腾出资源。

我们可以通过以下命令查看 Pod 的状态:

kubectl get pods
kubectl describe pod high-priority-pod
kubectl describe pod low-priority-pod

这些命令可以帮助你确认抢占是否发生。

三、实际应用中的注意事项

1. 资源规划

在实际应用中,设置 Pod 优先级需要仔细规划资源。确保高优先级 Pod 有足够的资源,并且不会对低优先级 Pod 造成过多的影响。

2. 监控和告警

实施优先级和抢占策略后,需要对集群进行监控,设置告警,以便及时发现和处理资源紧张或抢占导致的问题。

3. 综合考虑调度策略

在设计调度策略时,需要综合考虑优先级、亲和性、反亲和性等多种因素。确保在资源紧张的情况下,关键任务能够优先运行,同时保证系统的整体稳定性。

4. 测试和优化

在生产环境中实施优先级和抢占策略前,建议在测试环境中进行充分的测试,优化配置,确保策略的有效性和可靠性。

四、总结

通过设置 Pod 优先级和抢占机制,Kubernetes 提供了一种灵活的调度策略,能够保证关键任务在资源紧张时优先运行。然而,在实际应用中,需要综合考虑资源规划、调度策略和系统监控等多种因素,确保系统的整体稳定性和高可用性。

设置和管理 Pod 优先级和抢占机制是 Kubernetes 集群管理中的重要部分,希望本文能对你在实际操作中有所帮助。

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

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

相关文章

【论文解读】大模型算法发展

一、简要介绍 论文研究了自深度学习出现以来,预训练语言模型的算法的改进速度。使用Wikitext和Penn Treebank上超过200个语言模型评估的数据集(2012-2023年),论文发现达到设定性能阈值所需的计算大约每8个月减半一次,95%置信区间约为5到14个月…

雪花算法 集群uid重复问题 uid-generator-spring-boot-starter

1、在生成环境 在某个业务使用该插件生成uid,由于业务整合了 mybatis-plus模块 2、该业务是分部署集群部署以及使用的多线程获取uid,使用中发现唯一建冲突,生成的uid有重复。 然后查看日志发现 workerId 始终为0 怀疑是生成workerId出了问题。 查看跟…

开发日志:windows修复SSL漏洞CVE-2016-2183(3389端口)

漏洞危害: 具有足够资源的中间人攻击者可利用此漏洞,通过“birthday”攻击检测会在固定密码与已知纯文本之间泄露 XOR 的冲突,进而泄露密码文本(例如安全 HTTPS Cookie),并可能导致劫持经认证的会话。 参见《支持SSL 64位块大小的密码套件(SWEET32)-修复方案》 参考…

数据库编程中游标 连接 commit

在数据库编程中,关闭游标和连接是一个重要的步骤,确保资源正确地释放和数据库操作的完整性。 游标(Cursor)和连接(Connection)是数据库编程中两个关键但不同的概念。它们在数据库操作中的作用和功能有所不…

100个python的基本语法知识【下】

50. 压缩文件: import zipfilewith zipfile.ZipFile("file.zip", "r") as zip_ref:zip_ref.extractall("extracted")51. 数据库操作: import sqlite3conn sqlite3.connect("my_database.db") cursor conn.c…

公告 | 长安链v2.3.4版本更新,增强功能、健全性和易用性

近期长安链长期支持版本v2.3.4发布,在功能、健全性和易用性方面进行了升级,是长安链2.3.x将近两年来的第五个版本,支持2.3.x版本的平滑升级,欢迎升级体验。 主要功能迭代 在功能上新增PK模式下支持grpcs连接、sdk支持自定义规则订…

递归神经网络(RNN)及其预测和分类的Python和MATLAB实现

递归神经网络(Recurrent Neural Networks,RNN)是一种广泛应用于序列数据建模的深度学习模型。相比于传统的前馈神经网络,RNN具有记忆和上下文依赖性的能力,适用于处理具有时序关联性的数据,如文本、语音、时…

主流树模型讲解、行列抽样、特征重要性梳理总结

本文旨在总结一下常见树模型的行、列抽样特点以及特征重要性的计算方式,也会带着过一遍算法基本原理,一些细节很容易忘记啊。 主要是分类和回归两类任务,相信能搜索这篇文章的你,应该对树模型有一定的了解。 可以搜索 总结 &…

java设计模式:04-03-解释器模式

解释器模式 (Interpreter Pattern) 定义 解释器模式是一种行为型设计模式,它提供了解释语言(或表达式)文法的一种方法,通过定义一系列语言(或表达式)的解释器,将文法中的句子转换为计算结果。…

老鼠后五毒也来凑热闹!网红食品惊现「壁虎头」,胖东来已下架…

上周,老鼠有点忙,比如其连续被曝出,出现在了方便面知名品牌的调料包、知名连锁餐饮品牌的黄焖鸡饭中。‍‍‍‍‍‍‍‍‍‍‍‍‍‍ 在小柴「被「添加」进方便面、黄焖鸡饭?老鼠最近忙疯了……」这篇文章的评论区,柴油…

计算机视觉与面部识别:技术、应用与未来发展

引言 在当今数字化时代,计算机视觉技术迅速发展,成为人工智能领域的一个重要分支。计算机视觉旨在让机器理解和解释视觉信息,模拟人类的视觉系统。它在各行各业中发挥着重要作用,从自动驾驶汽车到智能监控系统,再到医疗…

数据库多表联查

一、内联查询 内联查询只有完全满足条件的数据才能出现的结果1.1 非等值联查 笛卡尔积,查到的结果具有不一致性 示例: select * from student,class1.2 等值查询 -- 查询出学生表和班级信息select * from student,class where student.classidclass.c…

物联网设备的画面(摄像头)嵌入到网页中,实时视频画面解决方案

一、将物联网设备的画面嵌入到网页中,通常有多种常见方式和解决方案。下面是一些常用的方法和技术: 1. 使用RTSP流 描述:通过RTSP协议流传输视频,可以通过播放器在网页中播放实时视频。解决方案: VLC.js:…

Python:对常见报错导致的崩溃的处理

Python的注释: mac用cmd/即可 # 注释内容 代码正常运行会报以0退出,如果是1,则表示代码崩溃 age int(input(Age: )) print(age) 如果输入非数字,程序会崩溃,也就是破坏了程序,终止运行 解决方案&#xf…

ios CCUIFont.m

// // CCUIFont.h // CCFC // //#import <Foundation/Foundation.h>// 创建字体对象 #define CREATE_FONT(fontSize) [UIFont systemFontOfSize:(fontSize)]interface UIFont(cc) (void)logAllFonts;end // // CCUIFont.m // CCFC // //#import "CCUIFont.h&…

贪心算法(三) ---cmp_to_key, 力扣452,力扣179

目录 cmp_to_key 比较函数 键函数 cmp_to_key 的作用 使用 cmp_to_key 代码解释 力扣452 ---射气球 题目 分析 代码 力扣179 ---最大数 题目 分析 代码 cmp_to_key 在Python中&#xff0c;cmp_to_key 是一个函数&#xff0c;它将一个比较函数转换成一个键函数…

Problems retrieving the embeddings data form OpenAI API Batch embedding job

题意&#xff1a;从OpenAI API批量嵌入作业中检索嵌入数据时遇到问题 问题背景&#xff1a; I have to embed over 300,000 products description for a multi-classification project. I split the descriptions onto chunks of 34,337 descriptions to be under the Batch e…

Nginx优化、防盗链

目录 Nginx优化 隐藏版本信息 网站缓存 日志切割 超时时间 更改进程数 网页压缩 防盗链 在使用源码软件包安装过Nginx服务&#xff0c;具体步骤看上一篇文章 功能模块位置 在Nginx的解压目录下的auto目录内的options文件可以查看Nginx可以安装的功能模块 [rootlocal…

关于InnoDB行锁和4种锁是怎么实现的?

InnoDB 的行锁实现主要基于索引&#xff0c;并通过多种类型的锁来确保数据的一致性和并发控制。以下是InnoDB行锁实现的几个关键点&#xff1a; 记录锁&#xff08;Record Locks&#xff09;&#xff1a;这种锁直接锁定某行记录的索引记录。它通常用于唯一索引或主键索引上&…

ubuntu20.04安装终端终结者并设置为默认终端

1、安装 terminator sudo apt-get install terminator 2、Ctrl Alt T 试一下打开什么终端&#xff0c;我的默认启动的是terminator;如果想换换默认的终端&#xff0c;还需以下一步 3、安装dconf-tools&#xff0c;这个是设置默认终端的必须 sudo apt-get install dconf-tools…