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