在 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,并设置其 priorityClassName 为 high-priority,这意味着该 Pod 的优先级为 1000。
二、Pod 的调度策略
1. 调度器按优先级排序悬决 Pod
Kubernetes 调度器在调度 Pod 时,会按优先级对悬决(Pending)Pod 进行排序。高优先级的 Pod 会比低优先级的 Pod 更早被调度。
例如,如果有两个悬决 Pod,一个优先级为 1000,另一个优先级为 500,调度器会优先尝试调度优先级为 1000 的 Pod。
2. 触发抢占逻辑
当调度器尝试调度一个高优先级 Pod 时,如果集群中没有满足其要求的节点,调度器会触发抢占逻辑。抢占逻辑会在当前节点中驱逐一个或多个低优先级的 Pod,以腾出资源调度高优先级的 Pod。
抢占逻辑的详细过程:
- 确定高优先级 Pod 的资源需求:调度器首先会确定高优先级 Pod 需要的资源(如 CPU 和内存)。
- 检查节点资源:调度器会检查每个节点,看看是否有满足高优先级 Pod 需求的可用资源。
- 触发抢占:如果没有节点满足要求,调度器会在节点中寻找低优先级的 Pod,并将其驱逐,以腾出资源。
- 调度高优先级 Pod:在腾出资源后,调度器会将高优先级 Pod 调度到该节点上。
3. Pod 的抢占策略与 Pod 间亲和性冲突
在某些情况下,高优先级 Pod 需要抢占低优先级 Pod,但这可能与 Pod 间的亲和性策略发生冲突。下面我们来探讨这种情况及其解决方案。
亲和性冲突的详细情景:
- 高优先级 Pod 未找到合适的调度节点:假设一个高优先级的 Pod 未能找到满足其资源需求的调度节点。
- 需要抢占低优先级 Pod:调度器决定需要驱逐一个低优先级的 Pod,以腾出资源。
- 亲和性冲突:高优先级 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 集群管理中的重要部分,希望本文能对你在实际操作中有所帮助。
相关文章:
在 Kubernetes 中设置 Pod 优先级及其调度策略详解
个人名片 🎓作者简介:java领域优质创作者 🌐个人主页:码农阿豪 📞工作室:新空间代码工作室(提供各种软件服务) 💌个人邮箱:[2435024119qq.com] 📱…...
Spring框架、02SpringAOP
SpringAOP 日志功能 基本方法 分析代码问题 目前代码存在两个问题 代码耦合性高:业务代码和日志代码耦合在了一起 代码复用性低:日志代码在每个方法都要书写一遍 问题解决方案 使用动态代理,将公共代码抽取出来 JDK动态代理 使用JDK动…...
基于python的网络爬虫爬取天气数据及可视化分析
要创建一个基于Python的网络爬虫来爬取天气数据并进行可视化分析,我们可以采用以下几个步骤来实现: 1. 选择数据源 首先,需要确定一个可靠的天气数据源。常用的有OpenWeatherMap、Weather API、Weatherstack等。这些API通常需要注册并获取一个API密钥(API Key)来使用。 …...
【WPF开发】上位机开发-串口收发
一、引言 在现代工业控制、嵌入式系统等领域,串口通信作为一种常见的通信方式,被广泛应用于各种场景。C#作为一门强大的编程语言,结合Windows Presentation Foundation(WPF)框架,可以轻松实现串口通信功能…...
ubuntu开启 远程登录 允许root远程登录
如果没有22端口服务 sudo apt update sudo apt install openssh-server sudo ufw allow.ssh sudo passwd root 修改配置文件 sudo vim /etc/ssh/sshd_config Port 22 修改为 Port 22 #PermitRootLogin prohibit-password 修改为 PermitRootLogin yes service ssh restart …...
《昇思25天学习打卡营第23天|RNN实现情感分类》
使用RNN进行情感分类:基于IMDB数据集的LSTM应用 引言 情感分析是自然语言处理(NLP)中的一个重要应用,广泛用于电影评论、社交媒体等文本数据的情感分类任务。本文将介绍如何使用递归神经网络(RNN)实现情感…...
机械设计基础B(学习笔记)
绪论 机构:是一些具备各自特点的和具有确定的相对运动的基本组合的统称。 组成机构的各个相对运动部分称为构件。构件作为运动单元,它可以是单一的整体,也可以是由几个最基本的事物(通常称为零件)组成的刚性结构。 构件…...
MybatisPlusException: Error: Method queryTotal execution error of sql 的报错解决
项目场景: 相关背景: 开发环境 开发系统时 系统页面加载正常 ,发布运行环境后运行一段时间,前端页面 突然出现 报错信息, 报错信息如下: MybatisPlusException: Error: Method queryTotal execution erro…...
人工智能领域的顶尖影响力人物(部分代表)
人工智能(AI)是模拟人类智能过程的计算机系统或机器的理论和开发。它致力于创建能够执行需要人类智能的任务的机器,如视觉感知、语音识别、决策制定和翻译之间的语言。AI领域包括机器学习、深度学习、自然语言处理等子领域,并涉及…...
Python:jsonl文件转json文件,并做字段处理
在使用LLaMA-Factory对shenzhi-wang/Llama3-8B-Chinese-Chat(https://huggingface.co/shenzhi-wang/Llama3-8B-Chinese-Chat/tree/main)进行微调时,希望使用COIG-CQIA的小红书数据集(https://huggingface.co/datasets/m-a-p/COIG-…...
安全产品在防御勒索病毒中的作用
在数字时代,网络安全威胁日益严峻,其中勒索病毒尤为猖獗,它通过加密受害者的数据并要求赎金换取解密密钥,给个人和企业带来了巨大的经济损失。然而,关于安全产品是否真正有效的问题一直存在争议。本文将通过一个模拟实…...
NVIDIA 完全过渡到开源 GPU 内核模块
目录 支持的 GPU安装程序更改将包管理器与 CUDA 元包配合使用使用 runfile使用安装帮助程序脚本包管理器详细信息apt:基于 Ubuntu 和 Debian 的发行版dnf:Red Hat Enterprise Linux、Fedora、Kylin、Amazon Linux 或 Rocky Linuxzypper:SUSE …...
learning-cxx 学习cpp 环境配置 + bug解决
学习CPP网址 https://github.com/LearningInfiniTensor/learning-cxx 安装环境 1.配置xmake的环境 xmake是c的构建工具 最简单的配置方法就是安装mcvs,然后选择必要的那两个包 查看版本,是否安装成功 gcc --version g --version2.安装xmake 我的是…...
PHP 多线程和异步编程的常见陷阱
本文由 ChatMoney团队出品 在PHP开发中,多线程和异步编程是提高应用性能和响应速度的重要手段。然而,这些技术也带来了许多挑战和陷阱,如共享状态冲突、死锁、超时、资源泄漏以及调试困难等。本文将详细探讨这些陷阱,并提供相应的…...
STL 哈希 学习总结
概述 基础概念 哈希是通过特定的算法,将任意长度的数据映射为固定长度的数据串中。该映射的结果就被称为哈希值,也可以称为散列值。 例如在存储一个10000这个数据的时候,如果使用数组的话,则需要开辟对应大小空间内存ÿ…...
vue3页面编写-导入导出excel、展开查询项等
数据保持 <router-view v-slot"{ Component, route }"><keep-alive><component :is"Component" :key"route.name" v-if"route.meta.keepAlive" /></keep-alive><component :is"Component" :key…...
Java学习 - Spring Boot整合 Thymeleaf 实例
什么是 Thymeleaf Thymeleaf 是新一代的 Java 模板引擎,类似于 Velocity、FreeMarker 等传统引擎,其语言和 HTML 很接近,而且扩展性更高; Thymeleaf 的主要目的是将优雅的模板引入开发工作流程中,并将 HTML 在浏览器中…...
ubuntu20.04安装终端终结者并设置为默认终端
1、安装 terminator sudo apt-get install terminator 2、Ctrl Alt T 试一下打开什么终端,我的默认启动的是terminator;如果想换换默认的终端,还需以下一步 3、安装dconf-tools,这个是设置默认终端的必须 sudo apt-get install dconf-tools…...
以Zookeeper为例 浅谈脑裂与奇数节点问题
一、脑裂现象的定义与影响 脑裂(split-brain)是指在分布式系统中,因网络分区或其他故障导致系统被切割成两个或多个相互独立的子系统,每个子系统可能独立选举出自己的领导节点。这一现象在依赖中心领导节点(如Elastic…...
最新版kubeadm搭建k8s(已成功搭建)
kubeadm搭建k8s(已成功搭建) 环境配置 主节点 k8s-master:4核8G、40GB硬盘、CentOS7.9(内网IP:10.16.64.67) 从节点 k8s-node1: 4核8G、40GB硬盘、CentOS7.9(内网IP:10…...
使用docker在3台服务器上搭建基于redis 6.x的一主两从三台均是哨兵模式
一、环境及版本说明 如果服务器已经安装了docker,则忽略此步骤,如果没有安装,则可以按照一下方式安装: 1. 在线安装(有互联网环境): 请看我这篇文章 传送阵>> 点我查看 2. 离线安装(内网环境):请看我这篇文章 传送阵>> 点我查看 说明:假设每台服务器已…...
WEB3全栈开发——面试专业技能点P2智能合约开发(Solidity)
一、Solidity合约开发 下面是 Solidity 合约开发 的概念、代码示例及讲解,适合用作学习或写简历项目背景说明。 🧠 一、概念简介:Solidity 合约开发 Solidity 是一种专门为 以太坊(Ethereum)平台编写智能合约的高级编…...
数据库分批入库
今天在工作中,遇到一个问题,就是分批查询的时候,由于批次过大导致出现了一些问题,一下是问题描述和解决方案: 示例: // 假设已有数据列表 dataList 和 PreparedStatement pstmt int batchSize 1000; // …...
mysql已经安装,但是通过rpm -q 没有找mysql相关的已安装包
文章目录 现象:mysql已经安装,但是通过rpm -q 没有找mysql相关的已安装包遇到 rpm 命令找不到已经安装的 MySQL 包时,可能是因为以下几个原因:1.MySQL 不是通过 RPM 包安装的2.RPM 数据库损坏3.使用了不同的包名或路径4.使用其他包…...
CSS设置元素的宽度根据其内容自动调整
width: fit-content 是 CSS 中的一个属性值,用于设置元素的宽度根据其内容自动调整,确保宽度刚好容纳内容而不会超出。 效果对比 默认情况(width: auto): 块级元素(如 <div>)会占满父容器…...
纯 Java 项目(非 SpringBoot)集成 Mybatis-Plus 和 Mybatis-Plus-Join
纯 Java 项目(非 SpringBoot)集成 Mybatis-Plus 和 Mybatis-Plus-Join 1、依赖1.1、依赖版本1.2、pom.xml 2、代码2.1、SqlSession 构造器2.2、MybatisPlus代码生成器2.3、获取 config.yml 配置2.3.1、config.yml2.3.2、项目配置类 2.4、ftl 模板2.4.1、…...
Python+ZeroMQ实战:智能车辆状态监控与模拟模式自动切换
目录 关键点 技术实现1 技术实现2 摘要: 本文将介绍如何利用Python和ZeroMQ消息队列构建一个智能车辆状态监控系统。系统能够根据时间策略自动切换驾驶模式(自动驾驶、人工驾驶、远程驾驶、主动安全),并通过实时消息推送更新车…...
Leetcode33( 搜索旋转排序数组)
题目表述 整数数组 nums 按升序排列,数组中的值 互不相同 。 在传递给函数之前,nums 在预先未知的某个下标 k(0 < k < nums.length)上进行了 旋转,使数组变为 [nums[k], nums[k1], …, nums[n-1], nums[0], nu…...
十九、【用户管理与权限 - 篇一】后端基础:用户列表与角色模型的初步构建
【用户管理与权限 - 篇一】后端基础:用户列表与角色模型的初步构建 前言准备工作第一部分:回顾 Django 内置的 `User` 模型第二部分:设计并创建 `Role` 和 `UserProfile` 模型第三部分:创建 Serializers第四部分:创建 ViewSets第五部分:注册 API 路由第六部分:后端初步测…...
API网关Kong的鉴权与限流:高并发场景下的核心实践
🔥「炎码工坊」技术弹药已装填! 点击关注 → 解锁工业级干货【工具实测|项目避坑|源码燃烧指南】 引言 在微服务架构中,API网关承担着流量调度、安全防护和协议转换的核心职责。作为云原生时代的代表性网关,Kong凭借其插件化架构…...
