1 展示出命名空间中的所有资源
kubectl get all -n rook-ceph
2 更新configmap
kubectl edit configmap -n -o yaml
3 关闭集群
nodes=$(kubectl get nodes -o name)
for node in ${nodes[@]}
do
echo "==== Shut down $node ===="
ssh $node sudo shutdown -h 1
done
4 rook ceph
rook-ceph 单节点退出就是点这里
中文解释drain
集体关机的话,备份好数据,按关机键吧
5 deployment
修改镜像重新push到镜像仓库后,可以不删deployment,只删pod 得到的就是最新的镜像,端口号还不变
# 获取上线状态
kubectl get rs
# 实时获取上线状态
kubectl get rs -w
# 查看都有哪些版本
kubectl rollout history deployment/nginx-deployment
# 查看版本详情
kubectl rollout history deployment/nginx-deployment --revision=2
# 回滚到指定版本
kubectl rollout undo deployment/nginx-deployment --to-revision=2
# 缩放
kubectl scale deployment/nginx-deployment --replicas=10
# 查看
kubectl get deployment nginx-deployment
将yaml存到文件里
kubectl get deploy -n ingress nginx-ingress-controller -o yaml > nginx-ingress-controller.yaml
StatefulSet
学到的更新都是更新 image
# 实时查看pod创建情况 -l参数是查找标签用的
kubectl get pods -w -l app=nginx
金丝雀:分阶段地发布
通过控制分区,来控制大于等于分区的image改变
# 设置分区
kubectl patch statefulset web -p '{"spec":{"updateStrategy":{"type":"RollingUpdate","rollingUpdate":{"partition":2}}}}'
# 改变pod image 版本
kubectl patch statefulset web --type='json' -p='[{"op": "replace", "path": "/spec/template/spec/containers/0/image", "value":"registry.k8s.io/nginx-slim:0.7"}]'
# 这样自动的大于等于分区的就会改变 image 版本
# 删除
kubectl delete sts web
# 删除 nginx Service
kubectl delete svc nginx
# 尽管你同时删除了 StatefulSet 和 web-0 Pod,但它仍然使用最初写入 index.html 文件的主机名进行服务。 这是因为 StatefulSet 永远不会删除和一个 Pod 相关联的 PersistentVolume 卷。 当你重建这个 StatefulSet 并且重新启动了 web-0 时,它原本的 PersistentVolume 卷会被重新挂载。