基于K8s调度器实现自定义调度

就是按照约定写代码,和我最开始写mysql UDF,hive自定义函数,都是一样的。

官方配置多个调度器:

https://kubernetes.io/zh/docs/tasks/extend-kubernetes/configure-multiple-schedulers/

背景:为了实现基于K8s的数据库服务的调度功能
难点:  1,原生K8s的资源只有cpu和mem,但是MySQL调度需要考虑磁盘资源,
            2,原生调度策略不符合线上环境,比如线上容器和物理机存在混跑,服务存在定制策略等
方案: 1,基于K8s 调度器的源码进行修改,定制化调度器,所有服务器调度时指定新调度器实现自定义策略
            2,将需要的元数据,比如MySQL端口容量,服务器磁盘容量等信息通过脚本同步到K8s中的annotations中
流程:
            1,下载调度器源码至本地服务器
 可从官方下载,此处原为内部git地址,省去
            2,本地修改完成后,编译,
CGO_ENABLED=0 GOOS=linux GOARCH=amd64  make all WHAT=cmd/kube-scheduler/
            3,编译完成&&没有报错,打包images 并 push到仓库
docker build -f Dockerfile -t registry.xxxx.xxxx.com.cn/xxxx/scheduler:1.0 .
docker login registry.xxx.xxx.com.cn -u xxxx
docker push registry.xxxx.xxxx.com.cn/xxxx/scheduler
            4,在南北K8s集群上找到运行着的 scheduler,并delete,scheduler以deployment方式部署,delete完成后确认下新scheduler是否running即可
kubectl get pod -n kube-system | grep kube-scheduler-db
kubectl delete pod kube-scheduler-db-xxxxxx-xxxxxxx -n kube-system
            5,至此 scheduler 更新流程流程,之后可以观察修改生效情况,重大更新建议先测试再正式上线
修改的细节(举例)
            scheduler 的目录结构如下
     
  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值