一个完整的创建Pod流程

一个完整的「创建Pod」流程:
通过
不通过
kubectl提交Pod创建请求
kube-apiserver
认证/授权/校验
写入etcd,标记Pod为「待调度」
返回错误
kube-scheduler监听API Server
筛选可用节点+打分
将Pod与节点绑定,写入etcd
目标节点的kubelet监听API Server
kubelet调用containerd
创建Pod和容器
kubelet定期上报Pod状态到API Server
API Server更新etcd中的Pod状态
kube-proxy监听API Server
创建iptables/IPVS规则,转发流量到Pod


具体步骤拆解:

  1. 运维通过kubectl run nginx --image=nginx提交请求,请求发送到kube-apiserver;
  2. API Server验证用户权限、Pod配置合法性,通过后将Pod信息写入etcd(状态为Pending);
  3. kube-scheduler通过API Server的Watch机制发现「待调度Pod」,执行调度算法,选择最优节点(如node2);
  4. scheduler将Pod与node2绑定,更新etcd中的Pod信息;
  5. node2上的kubelet通过Watch机制发现「分配给自己的Pod」,调用containerd拉取nginx镜像、创建容器;
  6. kubelet启动Pod后,定期向API Server上报Pod状态(Running),API Server更新etcd;
  7. kube-proxy监听Pod创建事件,在node2上创建iptables规则,确保Service能转发流量到该Pod;
  8. CoreDNS为Pod分配域名,网络插件为Pod分配IP,保证Pod能访问集群内其他服务。
相关推荐
恼书:-(空寄2 天前
K8s 网关(Ingress-Nginx/Envoy/云原生网关)20 个高频故障速查手册
云原生·k8s·ingress
w6100104665 天前
CKAD-2026-Secret
运维·k8s·ckad
w6100104665 天前
CKAD-2026-Ingress
运维·k8s·ckad
w6100104666 天前
CKAD-2026-金丝雀部署
linux·运维·服务器·k8s
xmlhcxr8 天前
kubernetes(K8s)基础配置及资源使用详解
docker·云原生·eureka·k8s
cool320010 天前
二进制基于kubeasz部署 K8s 1.34.x 高可用集群实战指南-第二章:HAProxy + Keepalived负载均衡高可用配置(2-4)
容器·k8s·负载均衡
国医中兴11 天前
边缘计算中的存储挑战与解决方案
微服务·云原生·容器·kubernetes·k8s
国医中兴12 天前
分布式存储的缓存优化:从理论到实践
微服务·云原生·容器·kubernetes·k8s
古城小栈12 天前
Jenkins+K8s实现Go后端服务自动化部署
go·k8s·jenkins
国医中兴14 天前
数据稠密计算的内存优化:从理论到实践
微服务·云原生·容器·kubernetes·k8s