- 默认k8s调度pod时,是根据资源请求(resources的requests)来调度,在调度的时候,会根据每个node上的所有的pod的requests总和对node进行打分,以确定该pod最终部署到哪台机器上
- 但是,有的用户在部署pod的时候,不写资源限制,或者不按照项目实际运行所需的资源写配置,就会导致某些node的资源requests总和不高,但是实际已经使用了很多了.调度上去的pod无法正常运行。
- 所以,需要一个调度器,根据资源实际使用情况调度pod,以保证每个node上的资源使用率。
计划: 修改打分策略,从metrics-server处获取node的资源使用情况,然后根据资源使用情况打分。
理论: 调库框架向现有的调度器中添加了一组插件化的 API,该 API 在保持调度程序“核心”简单且易于维护的同时,使得大部分的调度功能以插件的形式存在
参考文档:
- https://blog.csdn.net/fly910905/article/details/124000222
- https://developer.aliyun.com/article/766998
- https://zhuanlan.zhihu.com/p/113620537
- 使用git 下载kubernetes源码,签出对应版本的分支或tag。
- go mod中添加replace,(replace内容可以从 kubernetes源码的go.mod中复制出来,只复制替换路径为本地)
- 开发
- 打包
- 部署
- 新部署的插件,不能加入kube-scheduler的选举中。
- 插件要有足够的权限获取metrics-server的数据。
- 只能根据CPU和内存调度