k8s中pod的调度原理

API Server 接收请求: 当用户通过 kubectl 或其他 API 客户端提交一个新的 Pod 到 Kubernetes集群时,请求首先被发送到 API Server。

1.初始验证: API Server 对请求进行验证,包括语法和授权验证。

2.创建 Pod 对象: 验证通过后,API Server 会在 Etcd 存储系统中创建 Pod 对象。

3.调度器(Scheduler)的选择: Pod 对象创建完成后,会进入待调度状态。Kubernetes Scheduler 会监控这些待调度的 Pod。

4.预选(Predicates): Scheduler 会根据一系列预选条件(Predicates)来筛选出符合条件的节点。预选条件包括但不限于:
5.优先级(Priority): Scheduler 会对通过预选条件的节点进行优先级排序。每个 Pod 可以有一个优先级值,优先级较高的 Pod 会被优先调度。

6.选择最佳节点: 根据优先级排序的结果,Scheduler 会选择一个最佳的节点来运行 Pod。

7.绑定(Binding): 一旦选定节点,Scheduler 会创建一个绑定事件,将 Pod 绑定到该节点。这个绑定信息会发送给 API Server 并存储在 Etcd 中。

8.Kubelet 下载镜像: 节点上的 Kubelet 组件接收到 Pod 被绑定的信息后,会负责下载 Pod 所需的容器镜像。

9.Pod 创建与启动: Kubelet 创建并启动 Pod 中定义的容器。容器运行后,Kubelet 会向 API Server 上报 Pod 的状态。

Pod 调度的关键组件
API Server:接收用户的请求,并负责验证和创建 Pod 对象。
Etcd:分布式键值存储系统,用于存储集群的状态信息。
Scheduler:负责选择合适的节点来运行 Pod。
Kubelet:每个节点上的代理,负责与 API Server 通信,并在本地节点上创建和管理 Pod

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值