k8s scheduler几种扩展方式的关系及区别

网上关于scheduler扩展介绍的文章很多,但都是东说一句西说一嘴,完全没有逻辑性,对于逻辑建构者看着很痛苦,这篇文章不会深入教你怎么扩展,而是教你几种扩展方式的关系和逻辑结构:

目前Kubernetes支持五种方式实现客户自定义的调度算法,如下:

  • default-scheduler recoding: 直接在Kubernetes默认scheduler基础上进行添加,然后重新编译kube-scheduler,修改地方在scheduler-core核心代码,需要遵守扩展规则;

  • standalone: 实现一个与kube-scheduler平行的custom scheduler,相当于你自己fork了一份,深度定制,不遵守扩展点什么的规矩,自己魔改

  • scheduler extender: webhook的方式,kube-scheduler会调用它(http/https)作为默认调度算法的补充,在调度的每个可以hook的阶段调用对应的extender,本质上就是一个http服务,用python或者java写都可以,但是需要自己去拿各种cache并维护,且http方式io时间代价很高

  • scheduler framework: scheduler暴露出标准化的interface规范,你只需要按照interface写你自己的实现,重新编译kube-scheduler,类似于第一种方案,但是更加标准化,不会修改scheduler-core核心代码(说人话就是一个是实现接口即可修改无侵入,一个需要修改人家代码有侵入)

  • scheduler-plugins:社区维护的一套基于scheduler framework的封装层次更高的一个项目,你只需要实现自己的判断逻辑,其他的(node信息,pod信息,处理返回结果)你都不用关心,只要关心自己打分逻辑即可

一般不需要深度定制的,选择scheduler extender(性能要求不高且愿意自己维护cache的)和scheduler-plugins(性能要求高,只想实现自己判断逻辑其他都不想做的)方式即可

相关推荐
小翰子_18 小时前
Docker 常用笔记(速查版)
笔记·docker·容器
初学者_xuan18 小时前
26、K8S-Sidecar代理
云原生·容器·kubernetes
❥ღ Komo·18 小时前
K8S-EFK日志收集实战指南
云原生·容器·kubernetes
Lethehong18 小时前
RAG-全链路问答系统:从零到容器化部署的终极指南
docker·云原生·cnb
bing.shao18 小时前
Kubernetes 容错处理实战案例集锦
云原生·容器·kubernetes
.柒宇.18 小时前
shell脚本之Docker安装
运维·docker·容器
..Move...19 小时前
云原生运维企业级实战项目:CentOS Stream 8 下 Nginx 高可用集群部署
运维·云原生·centos
凯子坚持 c19 小时前
Docker存储卷深度解析:机制、管理与数据持久化实战
运维·docker·容器
古城小栈19 小时前
边缘计算:K3s 轻量级 K8s 部署实践
java·kubernetes·边缘计算
蟑螂恶霸19 小时前
使用docker安装windows 11
运维·docker·容器