在K8S中,创建一个Pod的主要流程是什么?

本文涉及的产品
容器服务 Serverless 版 ACK Serverless,952元额度 多规格
容器服务 Serverless 版 ACK Serverless,317元额度 多规格
简介: 在K8S中,创建一个Pod的主要流程是什么?

在Kubernetes(简称K8s)中创建一个Pod的主要流程如下:

  1. 用户请求
  • 用户通过kubectl命令行工具或API接口提交一个Pod的定义,通常是通过YAML或JSON格式的配置文件来描述Pod的详细信息,包括容器镜像、环境变量、资源需求、卷挂载等。
  1. API Server接收入口
  • 用户的请求首先到达Kubernetes API Server,API Server会对请求进行认证、授权和准入控制检查。
  1. 持久化存储到etcd
  • 一旦API Server验证了请求的有效性,它会将Pod的定义信息写入etcd(分布式键值存储),以确保集群内的所有组件都能获取最新的集群状态。
  1. 调度决策
  • 当Pod被创建并保存到etcd后,API Server会触发调度器(scheduler)对Pod进行调度。
  • 调度器根据集群节点的资源状况、亲和性和反亲和性规则以及其他约束条件,选择一个最适合运行Pod的Node,并更新Pod的状态为“Scheduled”。
  1. 绑定Pod至Node
  • 调度器将调度决定通知给API Server,由API Server将Pod与选定的Node进行绑定。
  1. kubelet执行
  • 相应节点上的kubelet进程通过监听API Server的事件,得知需要在其上创建新的Pod。
  • kubelet从etcd中获取该Pod的详细信息,然后开始执行创建Pod的具体工作,这包括:
  • 下载所需容器镜像
  • 创建网络命名空间和网络策略
  • 设置Pod的Volume(卷)
  • 启动Pod中的各个容器
  1. 容器启动
  • 容器运行时(如Docker或containerd)负责启动容器,并监控容器的生命周期事件,如健康检查、重启策略等。
  1. Pod就绪和运行
  • 当Pod中的所有容器均成功启动并且通过了就绪探针(readiness probe)检测,则kubelet会将Pod的状态报告回API Server,标记Pod为“Running”状态,此时Pod可以接受来自Service的流量。
  1. 持续监控与管理
  • 在Pod的整个生命周期内,kubelet和API Server将持续监视Pod的状态,并根据Pod的定义和系统策略进行相应的管理和维护操作。

综上所述,这个过程中还涉及到很多细节,例如 Pod 状态的变更、事件的记录、副本集控制器对Pod数量的自动管理等。以上是创建Pod的基本流程概述。

相关实践学习
通过Ingress进行灰度发布
本场景您将运行一个简单的应用,部署一个新的应用用于新的发布,并通过Ingress能力实现灰度发布。
容器应用与集群管理
欢迎来到《容器应用与集群管理》课程,本课程是“云原生容器Clouder认证“系列中的第二阶段。课程将向您介绍与容器集群相关的概念和技术,这些概念和技术可以帮助您了解阿里云容器服务ACK/ACK Serverless的使用。同时,本课程也会向您介绍可以采取的工具、方法和可操作步骤,以帮助您了解如何基于容器服务ACK Serverless构建和管理企业级应用。 学习完本课程后,您将能够: 掌握容器集群、容器编排的基本概念 掌握Kubernetes的基础概念及核心思想 掌握阿里云容器服务ACK/ACK Serverless概念及使用方法 基于容器服务ACK Serverless搭建和管理企业级网站应用
相关文章
|
18天前
|
JSON Kubernetes Shell
【Azure K8S | AKS】在不丢失文件/不影响POD运行的情况下增加PVC的大小
【Azure K8S | AKS】在不丢失文件/不影响POD运行的情况下增加PVC的大小
|
18天前
|
Kubernetes Shell Perl
【Azure K8S|AKS】进入AKS的POD中查看文件,例如PVC Volume Mounts使用情况
【Azure K8S|AKS】进入AKS的POD中查看文件,例如PVC Volume Mounts使用情况
|
19天前
|
Kubernetes Docker Perl
在K8S中,如果是因为开发写的镜像问题导致pod起不来该怎么排查?
在K8S中,如果是因为开发写的镜像问题导致pod起不来该怎么排查?
|
19天前
|
Kubernetes 安全 Docker
在K8S中,在服务上线的时候Pod起不来怎么进行排查?
在K8S中,在服务上线的时候Pod起不来怎么进行排查?
|
19天前
|
存储 Kubernetes 调度
在K8S中,⼀个pod的不同container能够分开被调动到不同的节点上吗?
在K8S中,⼀个pod的不同container能够分开被调动到不同的节点上吗?
|
19天前
|
消息中间件 Kubernetes 容器
在K8S中,同⼀个Pod的不同容器互相可以访问是怎么做到的?
在K8S中,同⼀个Pod的不同容器互相可以访问是怎么做到的?
|
19天前
|
存储 Kubernetes 数据中心
在K8S中,同⼀个Pod内不同容器哪些资源是共用的,哪些资源是隔离的?
在K8S中,同⼀个Pod内不同容器哪些资源是共用的,哪些资源是隔离的?
|
19天前
|
Kubernetes 负载均衡 网络协议
在K8S中,Pod的探针有哪些及用途?
在K8S中,Pod的探针有哪些及用途?
|
19天前
|
Kubernetes 监控 Perl
在K8S中,Pod⼀直处于Init状态,如何排查?
在K8S中,Pod⼀直处于Init状态,如何排查?
|
19天前
|
Prometheus Kubernetes 监控
在K8S中,Pod处于OOM状态如何排查?
在K8S中,Pod处于OOM状态如何排查?