Kubernetes技术与架构-调度 1

Kubernetes技术与架构集群对Pod的资源调度策略分为三个部分,其中包括匹配调度、优先调度以及终止调度,匹配调度是指将Pod匹配到适合、指定的Node服务器节点中运行,优先调度是指终止优先级低的Pod而优先匹配优先级高的Pod到适合的Node服务器节点中运行,终止调度是指停止Node服务器节点中的Pod的运行。

kube-scheduler调度器

Kubernetes集群的调度Pod资源分为两个步骤,第一个步骤是过滤(Filtering),第二步骤是打分(Scoring),过滤是指从集群的全部Node服务器节点找到调度该Pod的可行性Node集合,打分是指以评分的方式对过滤的Node集合实行排名而找出最适合调度该Pod的Node服务器节点。

如上所示,定义一个Pod,设定Pod的调度策略是使用Node选择器,在调度策略中设定匹配Node服务器节点的约束条件,required指定的是严格匹配的条件,即不匹配条件则不调度节点,preferred指定的是非严格匹配的条件,即优先调度匹配条件的节点,不匹配条件则调度其他节点

如上所示,指定weight权重的值,即在匹配过程中,计算到Node的服务器节点的权重值的总和,权重值的总和最大的Node服务器节点优先调度

如上所示,在Kubernetes集群中设置通用调度规则,即在pod中的.spec.schedulerName属性中可以指定foo-scheduler的调度策略

如上所示,定义一个Pod,设定Pod的调度策略是使用Pod选择器,匹配指定的topologyKey拓扑关系的区域内的Node节点,其中,podAffinity与podAntiAffinity的调度策略是相反的关系,即包括以及不包括的关系

如上所示,定义一个部署的模板,匹配的Pod则使用对应的调度策略

如上所示,定义一个Pod,同时定义podAffinity以及podAntiAffinity调度策略,其中,mismatchLabelKeys指定约束条件是不调度到其他已匹配的标签为tenant的Node服务器节点

如上所示,定义一个部署模板,在指定的拓扑关系内同时部署web以及cache,其中,使用podAntiAffinity部署规则指定每个Node服务器节点只能调度一个cache

如上所示,定义部署模板,podAffinity调度规则指定每个cache对应的Node服务器节点中只能调度一个web,podAntiAffinity调度规则指定不能在同一个Node服务器节点中调度多个web

如上所示,在三个Node服务器节点的Kubernetes集群中,部署web以及cache,每个Node服务器节点分别部署一个web以及一个cache

如上所示,定义一个Pod,在指定的nodeName服务器节点中调度

相关推荐
€☞扫地僧☜€1 小时前
docker 拉取MySQL8.0镜像以及安装
运维·数据库·docker·容器
58沈剑1 小时前
80后聊架构:架构设计中两个重要指标,延时与吞吐量(Latency vs Throughput) | 架构师之路...
架构
全能全知者2 小时前
docker快速安装与配置mongoDB
mongodb·docker·容器
想进大厂的小王4 小时前
项目架构介绍以及Spring cloud、redis、mq 等组件的基本认识
redis·分布式·后端·spring cloud·微服务·架构
阿伟*rui5 小时前
认识微服务,微服务的拆分,服务治理(nacos注册中心,远程调用)
微服务·架构·firefox
ZHOU西口5 小时前
微服务实战系列之玩转Docker(十八)
分布式·docker·云原生·架构·数据安全·etcd·rbac
deephub8 小时前
Tokenformer:基于参数标记化的高效可扩展Transformer架构
人工智能·python·深度学习·架构·transformer
景天科技苑8 小时前
【云原生开发】K8S多集群资源管理平台架构设计
云原生·容器·kubernetes·k8s·云原生开发·k8s管理系统
架构师那点事儿9 小时前
golang 用unsafe 无所畏惧,但使用不得到会panic
架构·go·掘金技术征文
wclass-zhengge9 小时前
K8S篇(基本介绍)
云原生·容器·kubernetes