我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Kubernetes调度算法是怎么使用的

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Kubernetes调度算法是怎么使用的

Kubernetes调度算法是怎么使用的,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。

调度流程

调度器就是一个独立的进程,负责不断从apiserver拉取还没有被调度的pod,以及可调度的node列表,通过一些列算法筛选,选出一个node并与该pod绑定,将绑定的结果写回apiserver

调度算法

下面讲解基于k8s v1.6.6的源码

算法需要经过两个阶段,分别是过滤和打分,首先过滤掉一部分,保证剩余的节点都是可调度的,接着在打分阶段选出最高分节点,该节点就是scheduler的输出节点。

过滤

过滤环节就是一条过滤器链,包含多个过滤器,每个相当于一个函数,接收node和待调度的pod作为参数,返回bool来确定是否可调度。通过组合多个函数可以完成一条可扩展的过滤器链。目前k8s中已注册的过滤器函数如下:

算法名称是否默认详细说明
NoVolumeZoneConflict当主机上zone-label(地区)包含pod中PersistentVolume卷下的zone label时,可以调度。当主机没有zone-label,表示没有没有zone限制,也可调度
MaxEBSVolumeCount当主机上被挂载的AWS EBS Volume超过了默认限制39,就不调度到该主机
MaxGCEPDVolumeCount当主机上被挂载的GCD Persistent Disk超过了默认限制16,就不调度到该机器
MaxAzureDiskVolumeCount当主机上被挂载的Azure Disk Volume超过了默认限制16,就不调度到该机器
NoDiskConflict

当主机上所有pod使用的卷和待调度pod使用的卷存在冲突,就不调度到该主机。这项检查只针对GCE, Amazon EBS, Ceph RBD, ISCSI,具体规则为:

  •       GCE PersistentDisk允许多次只读挂载相同的volume

  •       EBS禁止两个pod挂载同一个id的volume

  •       Ceph RBD禁止两个pod共享一个monitor、pool、image

  •       ISCSI禁止两个pod共享同一个IQN

MatchInterPodAffinity亲和性检查,设带调度的pod为X,当主机上所有正运行的pod与X不相互排斥时,则可调度 
PodToleratesNodeTaints当pod可以容忍(tolerate)主机所有的taint(污点)时,才可被调度(容忍taint标签的方式就是给自己也打上相应tolerations标签)
CheckNodeMemoryPressure当主机剩余内存紧张时,BestEffort类型的pod无法被调度到该主机
CheckNodeDiskPressure当主机剩余磁盘空间紧张时,无法调度到该主机 
PodFitsHostPorts当待调度pod中所有容器所用到的HostPort与工作节点上已使用端口存在冲突,就不调度到该主机 
PodFitsPorts被PodFitsHostPorts取代 
PodFitsResources当总资源-主机中所有pod对资源的request总量 < 带调度的pod request资源量,则不调度到该主机,现在会检查CPU,MEM,GPU资源
HostName如果待调度的pod指定了pod.Spec.Host,则调度到该主机上 
MatchNodeSelector 当主机label与pod中nodeSelector以及annotations  scheduler.alpha.kubernetes.io/affinity匹配,则可调度


打分

打分环节也是一条链路,包含多个打分函数,每个打分函数会接收node和待调度的pod作为参数,返回一个范围在0-10的分数,每个打分函数还有一个权重值。某个node算出的总分就是所有打分函数的分值*权重值的总和,获取总分最大的node(如果有多个,随机取一个),该node就是最终要被调度的节点

示例:假设有个节点nodeA,有两个打分函数priorityFunc1、priorityFunc2(每个方法都能返回一个score),两个方法分别都有权重因子weight1、weight2。则nodeA的总分为:finalScoreNodeA = (weight1 * priorityFunc1) + (weight2 * priorityFunc2)

目前k8s中已注册的打分函数如下:

算法名称是否默认权重详细说明
SelectorSpreadPriority1相同service/rc的pods越分散,得分越高
ServiceSpreadingPriority1相同service的pods越分散,优得分越高,被SelectorSpreadPriority取代,保留在系统中,并不使用
InterPodAffinityPriority1pod与node上正运行的其他pod亲和性匹配度越高,得分越高
LeastRequestedPriority1剩余资源越多,得分越高。cpu((capacity - sum(requested)) * 10 / capacity) + memory((capacity - sum(requested)) * 10 / capacity) / 2
BalancedResourceAllocation1cpu和内存利用率越接近,得分越高。10 - abs(cpuFraction-memoryFraction)*10
NodePreferAvoidPodsPriority10000当node的annotation scheduler.alpha.kubernetes.io/preferAvoidPods被设置时,说明该node不希望被调度,得分低,当没有设置时得分高。之所以权重较大是因为一旦设置preferAvoidPods表示该node不希望被调度,该项得分为0,其他没有设置的node得分均为10000*分值,相当于直接过滤掉该节点。思考:其实可以放在过滤环节处理
NodeAffinityPriority1pod与node的亲和性匹配度越高,得分越高
TaintTolerationPriority1pod对node的污点(taint)的容忍(tolerate)程度越高,得分越高
EqualPriority1所有机器得分一样
ImageLocalityPriority1待调度的pod会使用到一些镜像,拥有这些镜像越多的节点,得分越高
MostRequestedPriority1request资源越多,得分越高,与LeastRequestedPriority相反。(cpu(10 * sum(requested) / capacity) + memory(10 * sum(requested) / capacity)) / 2

关于Kubernetes调度算法是怎么使用的问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注编程网行业资讯频道了解更多相关知识。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Kubernetes调度算法是怎么使用的

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Kubernetes调度算法是怎么使用的

Kubernetes调度算法是怎么使用的,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。调度流程调度器就是一个独立的进程,负责不断从apiserver拉取还没有被调度的pod
2023-06-19

java线程调度算法是什么

Java线程调度算法是由Java虚拟机(JVM)负责的。JVM使用了一种抢占式调度算法,即根据线程的优先级来决定该调度哪个线程执行。JVM会根据线程的优先级和其他一些因素,如线程的等待时间、线程的状态等,来确定线程的调度顺序。在Java中,
2023-08-30

Java进程调度算法指的是什么

这篇文章主要介绍了Java进程调度算法指的是什么的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Java进程调度算法指的是什么文章都会有所收获,下面我们一起来看看吧。该工程主要有三个实现类:Process(进程类
2023-06-26

云服务器调度算法是什么

云服务器调度算法的主要组成部分包括:调度器:调度器是云服务器的核心部分,它负责对云服务器的请求进行分发和处理。调度器通常是一个计算机程序,它负责根据请求的内容和云服务器的性能来决定如何分发请求。调度器还要负责对请求进行监控和管理,以便在发生问题时能够及时处理。负载均衡器:负载均衡器是云服务器的另一个重要组成部分。它负责
2023-10-27

Java进程调度算法的概念是什么

这篇“Java进程调度算法的概念是什么”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Java进程调度算法的概念是什么”文章吧
2023-07-02

负载均衡调度算法是什么

负载均衡调度算法是一种用于分配请求到多个服务器的算法,以实现在不同服务器之间平衡负载的目的。负载均衡调度算法根据不同的策略和条件来选择合适的服务器,以提高系统的性能、可用性和可扩展性。常见的负载均衡调度算法包括:1. 轮询算法(Round
2023-09-02

golang调度器的用法是什么

Golang调度器是Go编程语言中的一种机制,用于协调并发执行的goroutine。调度器负责在可用的处理器上调度goroutine的执行,并管理它们的执行状态。调度器的使用方式是隐式的,开发者无需手动控制调度器的行为。当程序启动时,调度器
2023-10-20

django任务调度方法怎么使用

Django中的任务调度可以通过以下方法进行使用:1. 使用Django自带的任务调度器 - Django提供了一个内置的任务调度器,可以轻松地在项目中使用。首先,在settings.py文件中添加以下代码:```pythonINSTALL
2023-09-26

PyTorch策略梯度算法怎么使用

这篇文章主要介绍“PyTorch策略梯度算法怎么使用”,在日常操作中,相信很多人在PyTorch策略梯度算法怎么使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”PyTorch策略梯度算法怎么使用”的疑惑有所
2023-07-02

Python怎么实现任务调度并行算法

本篇内容介绍了“Python怎么实现任务调度并行算法”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!本来自己想先使用Java来写一个版本,然后
2023-06-04

怎么用C语言递归实现火车调度算法

这篇文章主要介绍怎么用C语言递归实现火车调度算法,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!1、代码题目如下:2.8编号为1,2,3,4的四列火车通过一个栈式的列车调度站,可能得到的调度结果有哪些?如果有n列火车通
2023-06-25

分时操作系统中使用的调度算法有哪些?

分时操作系统中,调度算法决定了不同进程如何被分配到CPU。本文将探讨分时操作系统中常用的几种调度算法,包括轮转调度、优先级调度和时间片轮转调度。
分时操作系统中使用的调度算法有哪些?
2024-03-05

scala怎么调用python算法

在Scala中调用Python算法有多种方法,以下是几种常用的方法:1. 使用Scala的sys.process库调用Python脚本:scalaimport sys.process._// 调用Python脚本val result = "
2023-10-23

python阻塞调度的使用方法

这篇文章主要介绍python阻塞调度的使用方法,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!python有哪些常用库python常用的库:1.requesuts;2.scrapy;3.pillow;4.twisted
2023-06-14

编程语言中任务调度的并行算法是什么

编程语言中任务调度的并行算法是什么,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。如果给定一批任务,比如有500个任务,需要在尽可能快的时间内做完。如果串行是肯定不行的。我们
2023-06-02

java任务调度quartz怎么使用

要使用Quartz任务调度器,您需要按照以下步骤进行操作:1. 首先,您需要添加Quartz的依赖项到您的项目中。您可以在Maven项目中添加以下依赖项:```xmlorg.quartz-schedulerquartz2.3.2```2.
2023-08-14

Go调度器学习之系统调用的方法是什么

本篇内容主要讲解“Go调度器学习之系统调用的方法是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Go调度器学习之系统调用的方法是什么”吧!1. 系统调用下面,我们将以一个简单的文件打开的系统
2023-07-05

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录