一个完整的创建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能访问集群内其他服务。
相关推荐
j200103221 天前
Prometheus
k8s·prometheus
淡泊if3 天前
K8s 网络排障:从抓包开始,一步步定位诡异“502”
网络·kubernetes·k8s
WAIT_TIME7 天前
RKE2 + KubeSphere 部署方案
k8s·kubesphere·rancher·rke2
稀样8 天前
常见的学习资料网站
k8s·jenkins
老友@9 天前
云计算的统一心智模型
开发语言·ci/cd·docker·云计算·k8s·perl
j2001032224 天前
Gateway—— 高级流量路由
gateway·k8s
西门吹雪分身1 个月前
K8S之Ingress
java·容器·kubernetes·k8s
小义_1 个月前
【Kubernetes】(二)k8s基础
linux·云原生·k8s
小义_1 个月前
【Kubernetes】(一)k8s基础
云原生·k8s