kubernetes-handbook/concepts/scheduling.md

13 lines
1.5 KiB
Markdown
Raw Blame History

This file contains ambiguous Unicode characters!

This file contains ambiguous Unicode characters that may be confused with others in your current locale. If your use case is intentional and legitimate, you can safely ignore this warning. Use the Escape button to highlight these characters.

# 资源调度
Kubernetes作为一个容器编排调度引擎资源调度是它的最基本也是最重要的功能这一节中我们将着重讲解Kubernetes中是如何做资源调度的。
Kubernetes中有一个叫做`kube-scheduler`的组件,该组件就是专门监听`kube-apiserver`中是否有还未调度到node上的pod再通过特定的算法为pod指定分派node运行。
Kubernetes中的众多资源类型例如Deployment、DaemonSet、StatefulSet等都已经定义了Pod运行的一些默认调度策略但是如果我们细心的根据node或者pod的不同属性分别为它们打上标签之后我们将发现Kubernetes中的高级调度策略是多么强大。当然如果要实现动态的资源调度即pod已经调度到某些节点上后因为一些其它原因想要让pod重新调度到其它节点。
考虑以下两种情况:
- 集群中有新增节点想要让集群中的节点的资源利用率比较均衡一些想要将一些高负载的节点上的pod驱逐到新增节点上这是kuberentes的scheduler所不支持的需要使用如[descheduler](https://github.com/kubernetes-incubator/descheduler)这样的插件来实现。
- 想要运行一些大数据应用设计到资源分片pod需要与数据分布达到一致均衡避免个别节点处理大量数据而其它节点闲置导致整个作业延迟这时候可以考虑使用[kube-batch](https://github.com/kubernetes-incubator/kube-batch)。