K8s中,deployment 是如何从 yaml 文件最终部署成功 pod 的

在Kubernets中,Deployment从YAML文件最终部署为Pod的过程涉及多个组件协同工作,大致可以分为以下几个关键步骤:

1、提交Deployment TAML

用户通过kubectl apply -f deployment.yaml 提交配置

kubectl将YAML转换为API请求发送给Kubernetes API Server

2、API Server 处理

验证YAML配置的合法性(语法、字段约束等)

将Deployment对象存储到etcd数据库中

触发对象创建的事件通知

3、Deployment Controller 介入

Deployment Controller 是一个持续运行的控制循环

检测到新的Deployment对象后,根据配置创建ReplicaSet

4、ReplicaSet Controller 工作

ReplicaSet Controller 监听新创建的ReplicaSet

根据replicas 字段确定需要创建的Pod数量

5、Scheduler 调度Pod

Scheduler 负责为未调度的Pod选择合适的节点

基于节点资源、亲和性规则、污点/容忍等策略进行调度

将调度结果(绑定到特定节点) 更新到API Server

6、Kubelet 启动容器

目标节点上的Kubelet定期从API Server 同步Pod信息

发现分配给自己的新Pod后,通过容器运行时创建容器

拉取镜像、挂载存储卷、配置网络等

将容器状态更新回API Server

7、状态维护

各控制器持续监控对象状态,确保实际状态与期望状态一致

如果Pod异常终止,ReplicaSet会自动创建新的Pod替换

整个过程Kubernetes的"声明式 API"和"控制循环"设计理念,用户只需定义期望状态,Kubernetes会自动协调实现该状态。

相关推荐
武子康2 天前
调查研究-183 Apple container:Mac 上用轻量 VM 跑 Linux 容器,Swift 会改写本地容器体验吗?
docker·容器·apple
秋播2 天前
国内本地WSL2编译rancher源码
云原生
小猿姐4 天前
MySQL Top 10 热点问题 AI 运维实战:从内核诊断到云原生运维
mysql·云原生·aiops
阿里云云原生5 天前
深入内核:拆解 OpenTelemetry eBPF 探针如何优雅地“透视”多语言微服务?
云原生
2601_961875245 天前
决战申论100题2026|最新|范文
linux·容器·centos·debian·ssh·fabric·vagrant
java_cj5 天前
深入kube-apiserver认证机制:从Bearer Token到mTLS的完整认证链解析
linux·运维·服务器·云原生·容器·kubernetes
程序员老赵5 天前
服务器没有桌面?Docker 跑个 Chrome,浏览器就能远程用
docker·容器·devops
正经教主5 天前
【docker基础】 第八周:容器监控与应用更新策略
运维·docker·容器
kiros_wang5 天前
Docker 使用完整指南
运维·docker·容器
正经教主5 天前
【docker基础】第九周:Docker安全与镜像优化
运维·docker·容器