kubectl是直接操作APTServer的,所以就相当于我们的清单提交给APIServer,然后集群获取到清单描述的应用信息后存入etcd数据库中,然后kube-scheduler组件发现一有一个pod还没绑定到节点上,就会对这个pod进行一系列的调度,把他调度到一个合适的节点上,这个合适可以是pod上约束也可以是node约束,后面讲。
调度好后,把这个节点和pod绑定到一起,回写etcd,然后节点上的kubelet组件这个时候watch到一个pod被分配过来了,就去吧这个pod的信息拉取下来,然后根据描述通过容器运行时,可以使docker也可以是其他的,把容器创建起来,最后当然同样吧pod状态写回etcd,完成创建流程。
apiVersion: apps/v1 //头部信息
kind: Deployment
metadata:
name: nginx-deploy
labels:
chapter: first-app //标签
spec:
selector: //选择器
matchLabels:
app: nginx //此处需要跟pod模板相同
replicas: 2 //副本数量
template: //pod模板
metadata:
labels:
app: nginx
spec:
containers:
- name : nginx
image: nginx:latest //指定容器镜像名
ports:
- containerPort: 80 //容器内部端口