scheduler调度过程:
    Predicate(预选)-->Priority(优选)-->Select(选定)
调度方式:
    1.节点亲和性调度(NodeAffinity)使用nodeSelector完成这类调度。
    2.Pod亲和性和反亲和性调度(PodAffinity、PodUnAffinity)。
    3.污点、污点容忍调度。节点上(Taints污点)、Pod上(Tolerations容忍度)。
参考:
预选策略:https://github.com/kubernetes/kubernetes/tree/master/pkg/scheduler/algorithm/predicates    
优选函数:https://github.com/kubernetes/kubernetes/tree/master/pkg/scheduler/algorithm/priorities

预选策略:(几种常用的预选策略)
    CheckNodeCondition:检查节点条件。是否可以在节点上的磁盘、网络不可用或未准备好的前提下把Pod调度到此节点。
    GeneralPredicates:通用预选策略,包含多种策略:
        HostName:检查Pod对象是否定义pod.spec.hostname
        PodFitsHostPort:检查Pod对象是否定义pod.spec.containers.ports.hostPort
        MatchNodeSelector:pods.spec.nodeSelector
        PodFitsResources:检查Pod的资源需求是否能被节点所满足。
    NoDiskConflict: 检查Pod依赖的存储卷能否能满足需求。
    PodToleratesNodeTaints:检查Pod上的spec.tolerations可容忍的污点是否完全包含节点上的污点。
    PodToleratesNodeNoExecuteTaints:Pod允许节点不执行污染;默认不启用。
    CheckNodeLabelPresence:检查节点标签;默认不启用
    CheckserviceAffinity:检查服务亲和性。默认不启用
    
    MaxEBSVolumeCount:亚马逊弹性存储卷最大数量,默认39
    MaxGCEPDVolumeCount:谷歌容器引擎最大存储卷数量,默认16
    MaxAzureDiskVolumeCount:Azure最大磁盘数量,默认16
    
    CheckVolumeBinding:检查数据卷绑定
    NoVolumeZoneConflict:没有数据卷空间冲突
    CheckNodeMemoryPressure:定义检查节点内存压力名称
    CheckNodePIDPressure:定义检查节点PID压力的名称
    CheckNodeDiskPressure:定义检查节点磁盘压力的名称
    
    MatchInterPodAffinity:定义匹配POD间关联的名称

优选函数:(几种常见的优选函数)
    LeastRequested:
        (cpu(capacity-sum(requested))*10/capacity)+(memory(capacity-sum(requested))*10/capacity)/2
    BalancedResourceAllocation:
        CPU和内存资源的被占用率相近的胜出;目的是平衡节点资源的使用率。
    NodePreferAvoidPods:
        节点注解信息"scheduler.alpha.kubernetes.io/preferAvoidPods"
    TaintToleration:
        将Pod对象的spec.tolerations与节点的taints列表项进行匹配度检查,匹配的条目越多得分越低。
    SelectorSpreading:调度器将pod分散调度。
    InterPodAffinity:根据Pod间的亲和性。
    NodeAffinity:根据节点亲和性。
    MostRequested:根据最多被请求的节点。
    NodeLabel:根据节点标签
    ImageLocality:
        根据满足当前Pod对象需求的已有镜像的体积大小之和。

k8s调度的预选策略及优选函数的更多相关文章

  1. 05-k8s调度器、预选策略、优选函数

    目录 k8s调度器.预选策略.优选函数 节点选择过程 调度器 预选策略 优选函数 高级调度设置机制 node选择器/node亲和调度 pod亲和性 污点调度 Taints 与 Tolerations ...

  2. k8s之调度器、预选策略及优选函数

    1.调度器(scheduler) 调度器的功能是调度Pod在哪个Node上运行,这些调度信息存储在master上的etcd里面,能够和etcd打交道的只有apiserver; kubelet运行在no ...

  3. K8S 调度器,预选策略,优选函数

    Kubernetes Scheduler 提供的调度流程分三步: 预选策略(predicate) 遍历nodelist,选择出符合要求的候选节点,Kubernetes内置了多种预选规则供用户选择. 优 ...

  4. K8s预选策略和优选函数简介

    调度器选择策略: 预选策略(Predicate) 1. 根据运行Pod的资源限制来排除不符合要求的Node 2. 根据运行Pod时,是否要求共享宿主机的网络名称空间来判断,如: 某Pod启动要共享宿主 ...

  5. Kubernetes 学习20调度器,预选策略及优选函数

    一.概述 1.k8s集群中能运行pod资源的其实就是我们所谓的节点,也称为工作节点.master从本质上来讲,他其实是运行整个集群的控制平面组件的比如apiserver,scheal,controlm ...

  6. k8s-调度器、预选策略及优选函数-二十

    一.简介 master上运行着三个最核心的组件,apiserver.scheduler.controller manager.此外,master还依赖于ectd存储节点,最好ectd是有冗余能力的集群 ...

  7. k8s调度器、预选策略及调度方式

    一.k8s调度流程 1.(预选)先排除完全不符合pod运行要求的节点2.(优先)根据一系列算法,算出node的得分,最高没有相同的,就直接选择3.上一步有相同的话,就随机选一个 二.调度方式 1.no ...

  8. 7.k8s.调度器scheduler 亲和性、污点

    #k8s. 调度器scheduler 亲和性.污点 默认调度过程:预选 Predicates (过滤节点) --> 优选 Priorities(优先级排序) --> 优先级最高节点 实际使 ...

  9. 图解kubernetes调度器预选设计实现学习

    Scheduler中在进行node选举的时候会首先进行一轮预选流程,即从当前集群中选择一批node节点,本文主要分析k8s在预选流程上一些优秀的筛选设计思想,欢迎大佬们指正 1. 基础设计 1.1 预 ...

随机推荐

  1. 已知单链表的数据元素为整型数且递增有序,L为单链表的哨兵指针。编写算法将表中值大于X小于Y的所有结点的顺序逆置。(C语言)

    对此题目的完整示例可直接运行代码如下: #include <stdio.h> #include <stdlib.h> typedef struct LNode{ int dat ...

  2. 搞定vscode编写java

    下载vscode: 地址: https://code.visualstudio.com/ 安装插件 我这里下载的是绿色版,所以解压后 向桌面发送一个快捷方式 找到VS Code 的快捷方式位置: 右键 ...

  3. 使用表达式目录树实现SqlDataReader到实体的映射

    SqlDataReader映射实体,是ORM的基础功能,常见的实现方式有反射.表达式目录树和emit,这里要说的就是用表达式目录树生成实体的方法. 先分析下思路: 假设有个数据实体类,Student ...

  4. 076 Minimum Window Substring 最小窗口子字符串

    给定一个字符串 S 和一个字符串 T,找到 S 中的最小窗口,它将包含复杂度为 O(n) 的 T 中的所有字符.示例:S = "ADOBECODEBANC"T = "AB ...

  5. 一、Postgresql的基本操作

    ---------------------------------------------------------------------------------------------------- ...

  6. this的那点事

    对于很多初学者,this总是搞得我们晕头转向. 现在,我就简单的总结一下关于this的那点事. this在函数定义时经常是不能确定的,只有在函数执行的时候才能最终确定this的归属.this总是指向最 ...

  7. window.open()弹出窗口参数说明及居中设置

    window.open()可以弹出一个新的窗口,并且通过参数控制窗口的各项属性. 最基本的弹出窗口代码 window.open('httP://codeo.cn/'); window.open()各参 ...

  8. Windows下Python多版本共存

    Windows下Python多版本共存 Python数据科学安装Numby,pandas,scipy,matpotlib等(IPython安装pandas) 0.0 因为公司项目,需要Python两个 ...

  9. GIT SSH免登录密码实现更新(git pull)、推送(git push)操作

     一.使用场景 现在有两台服务器A和B,在A服务器上搭建有git版本代码仓库,现要实现B服务器SSH免密码登录A服务器,并能够从A服务器拉取.推送代码! 二.操作步骤 1.在B服务器项目根目录下执行以 ...

  10. 小目标 | Power BI新人快速上手手册

    · 适用人群:数据分析专业人士,在数据分析方向需求发展人士 · 应用场景:数据汇报.数据可视化展现.数据建模分析 · 掌握难度:★★★★☆ 本期讲师 『PowerPivot工坊』公众号提供Power ...