伸缩(Scale Up/Down)是指在线增加或减少 Pod 的副本数。
1.增加副本
Deployment nginx-deployment初始是两个副本。
[root@k8s-master k8s]# kubectl apply -f nginx.yaml deployment.extensions/nginx-deployment created [root@k8s-master k8s]# kubectl get pod -o wide NAME READY STATUS RESTARTS AGE IP NODE NOMINATED NODE nginx-deployment-57f56449d9-8b9xp 1/1 Running 0 16s 10.244.2.11 k8s-node1 <none> nginx-deployment-57f56449d9-lnxlb 1/1 Running 0 16s 10.244.1.11 k8s-node2 <none>
现在将配置文件中原先replicas为2 改为5 pod将会怎么分布
[root@k8s-master k8s]# kubectl apply -f nginx.yaml
deployment.extensions/nginx-deployment configured
2.master节点工作负载选择
这里由于我将master节点去除了污点,所以他既是管理节点也是工作节点。
下面的命令就是去除master节点污点的命令
kubectl taint node k8s-master node-role.kubernetes.io/master-
如果不想让master节点参与到工作负载
kubectl taint node k8s-master node-role.kubernetes.io/master="":NoSchedule
删除deployment 重新执行
[root@k8s-master k8s]# kubectl delete -f nginx.yaml deployment.extensions "nginx-deployment" deleted
3.减少副本
接下来修改配置文件,将副本数减少为 3 个,重新执行 kubectl apply
:
可以看到两个副本被删除,最终保留了 3 个副本。