
11-k8s实战-资源调度
资源调度
Label 和 Selector
标签(Label)
配置文件
在各类资源的 metadata.labels 中进行配置
zho
kubectl
1 | #临时创建label |
选择器(selector)
-
配置文件:在各对象的配置 spec.selector 或其他可以写 selector 的属性中编写
-
kubectl命令
1
2
3
4
5
6
7
8
9
10
11
12# 匹配单个值,查找 app=hello 的 pod
kubectl get po -A -l app=hello
# 匹配多个值
kubectl get po -A -l 'k8s-app in (metrics-server, kubernetes-dashboard)'
或
# 查找 version!=1 and app=nginx 的 pod 信息
kubectl get po -l version!=1,app=nginx
# 不等值 + 语句
kubectl get po -A -l version!=1,'app in (busybox, nginx)'
Deployment
功能
-
创建
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15创建一个 deployment
kubectl create deploy nginx-deploy --image=nginx:1.7.9
或执行
kubectl create -f xxx.yaml --record
--record 会在 annotation 中记录当前命令创建或升级了资源,后续可以查看做过哪些变动操作。
查看部署信息
kubectl get deployments
查看 rs
kubectl get rs
查看 pod 以及展示标签,可以看到是关联的那个 rs
kubectl get pods --show-labels -
滚动更新
只有修改了 deployment 配置文件中的 template 中的属性后,才会触发更新操作
修改 nginx 版本号
1
kubectl set image deployment/nginx-deployment nginx=nginx:1.9.1
或者通过 kubectl edit deployment/nginx-deployment 进行修改
查看滚动更新的过程
1
kubectl rollout status deploy <deployment_name>
查看部署描述,最后展示发生的事件列表也可以看到滚动更新过程
1
kubectl describe deploy <deployment_name>
通过 kubectl get deployments 获取部署信息,UP-TO-DATE 表示已经有多少副本达到了配置中要求的数目
通过 kubectl get rs 可以看到增加了一个新的 rs
通过 kubectl get pods 可以看到所有 pod 关联的 rs 变成了新的
多个滚动更新并行
假设当前有 5 个 nginx:1.7.9 版本,你想将版本更新为 1.9.1,当更新成功第三个以后,你马上又将期望更新的版本改为
1.9.2,那么此时会立马删除之前的三个,并且立马开启更新 1.9.2 的任务 -
回滚
有时候你可能想回退一个Deployment,例如,当Deployment不稳定时,比如一直crash looping。
默认情况下,kubernetes会在系统中保存前两次的Deployment的rollout历史记录,以便你可以随时会退(你可以修改revision history
limit来更改保存的revision数)。案例:
更新 deployment 时参数不小心写错,如 nginx:1.9.1 写成了 nginx:1.911
kubectl set image deployment/nginx-deploy nginx=nginx:1.91
监控滚动升级状态,由于镜像名称错误,下载镜像失败,因此更新过程会卡住
1
kubectl rollout status deployments nginx-deploy
结束监听后,获取 rs 信息,我们可以看到新增的 rs 副本数是 2 个
1
kubectl get rs
通过 kubectl get pods 获取 pods 信息,我们可以看到关联到新的 rs 的 pod,状态处于 ImagePullBackOff 状态
为了修复这个问题,我们需要找到需要回退的 revision 进行回退
通过kubectl rollout history deployment/nginx-deploy可以获取 revison 的列表通过
kubectl rollout history deployment/nginx-deploy --revision=2可以查看详细信息确认要回退的版本后,可以通过
kubectl rollout undo deployment/nginx-deploy可以回退到上一个版本也可以回退到指定的 revision
1
kubectl rollout undo deployment/nginx-deploy --to-revision=2
再次通过
kubectl get deployment和kubectl describe deployment可以看到,我们的版本已经回退到对应的 revison 上了可以通过设置 .spec.revisonHistoryLimit 来指定 deployment 保留多少 revison,如果设置为 0,则不允许 deployment 回退了。
-
扩容缩容
通过 kube scale 命令可以进行自动扩容/缩容,以及通过 kube edit 编辑 replcas 也可以实现扩容/缩容
扩容与缩容只是直接创建副本数,没有更新 pod template 因此不会创建新的 rs
-
暂停与恢复
由于每次对 pod template 中的信息发生修改后,都会触发更新 deployment
操作,那么此时如果频繁修改信息,就会产生多次更新,而实际上只需要执行最后一次更新即可,当出现此类情况时我们就可以暂停
deployment 的 rollout通过
kubectl rollout pause deployment <name>就可以实现暂停,直到你下次恢复后才会继续进行滚动更新尝试对容器进行修改,然后查看是否发生更新操作了
1
2kubectl set image deploy <name> nginx=nginx:1.17.9
kubectl get po
配置文件
1 | apiVersion: apps/v1 # deployment api 版本 |
StatefulSet
功能
-
创建
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16kubectl create -f web.yaml
# 查看 service 和 statefulset => sts
kubectl get service nginx
kubectl get statefulset web
# 查看 PVC 信息
kubectl get pvc
# 查看创建的 pod,这些 pod 是有序的
kubectl get pods -l app=nginx
# 查看这些 pod 的 dns
# 运行一个 pod,基础镜像为 busybox 工具包,利用里面的 nslookup 可以看到 dns 信息
kubectl run -i --tty --image busybox dns-test --restart=Never --rm /bin/sh
nslookup web-0.nginx -
扩容缩容
1
2
3
4
5# 扩容
$ kubectl scale statefulset web --replicas=5
# 缩容
$ kubectl patch statefulset web -p '{"spec":{"replicas":3}}' -
镜像更新
1
2# 镜像更新(目前还不支持直接更新 image,需要 patch 来间接实现)
kubectl patch sts web --type='json' -p='[{"op": "replace", "path": "/spec/template/spec/containers/0/image", "value":"nginx:1.9.1"}]'-
RollingUpdate
StatefulSet 也可以采用滚动更新策略,同样是修改 pod template 属性后会触发更新,但是由于 pod 是有序的,在 StatefulSet
中更新时是基于 pod 的顺序倒序更新的-
灰度发布
利用滚动更新中的 partition 属性,可以实现简易的灰度发布的效果
例如我们有 5 个 pod,如果当前 partition 设置为 3,那么此时滚动更新时,只会更新那些 序号 >= 3 的 pod
利用该机制,我们可以通过控制 partition 的值,来决定只更新其中一部分 pod,确认没有问题后再主键增大更新的 pod
数量,最终实现全部 pod 更新
-
-
OnDelete
只有在 pod 被删除时会进行更新操作
-
-
删除
1
2
3
4
5
6
7# 删除 StatefulSet 和 Headless Service
# 级联删除:删除 statefulset 时会同时删除 pods
kubectl delete statefulset web
# 非级联删除:删除 statefulset 时不会删除 pods,删除 sts 后,pods 就没人管了,此时再删除 pod 不会重建的
kubectl deelte sts web --cascade=false
# 删除 service
kubectl delete service nginx -
删除pvc
1
2# StatefulSet删除后PVC还会保留着,数据不再使用的话也需要删除
$ kubectl delete pvc www-web-0 www-web-1
配置文件
1 |
|


