kubernetes 节点维护 cordon, drain, uncordon
来源:互联网 发布:网络架空防静电地板 编辑:程序博客网 时间:2024/05/17 02:45
这三个命令是正式release的1.2新加入的命令,三个命令一起介绍,是因为三个命令配合使用可以实现节点的维护。在1.2之前,因为没有相应的命令支持,如果要维护一个节点,只能stop该节点上的kubelet将该节点退出集群,是集群不在将新的pod调度到该节点上。如果该节点上本生就没有pod在运行,则不会对业务有任何影响。如果该节点上有pod正在运行,kubelet停止后,master会发现该节点不可达,而将该节点标记为notReady状态,不会将新的节点调度到该节点上。同时,会在其他节点上创建新的pod替换该节点上的pod。这种方式虽然能够保证集群的健壮性,但是任然有些暴力,如果业务只有一个副本,而且该副本正好运行在被维护节点上的话,可能仍然会造成业务的短暂中断。
1.2中新加入的这3个命令可以保证维护节点时,平滑的将被维护节点上的业务迁移到其他节点上,保证业务不受影响。
如下图所示是一个整个的节点维护的流程(为了方便demo增加了一些查看节点信息的操作):
1)首先查看当前集群所有节点状态,可以看到共四个节点都处于ready状态;
2)查看当前nginx两个副本分别运行在d-node1和k-node2两个节点上;
3)使用cordon命令将d-node1标记为不可调度;
4)再使用kubectl get nodes查看节点状态,发现d-node1虽然还处于Ready状态,但是同时还被禁能了调度,这意味着新的pod将不会被调度到d-node1上。
5)再查看nginx状态,没有任何变化,两个副本仍运行在d-node1和k-node2上;
6)执行drain命令,将运行在d-node1上运行的pod平滑的赶到其他节点上;
7)再查看nginx的状态发现,d-node1上的副本已经被迁移到k-node1上;这时候就可以对d-node1进行一些节点维护的操作,如升级内核,升级Docker等;
8)节点维护完后,使用uncordon命令解锁d-node1,使其重新变得可调度;
9)检查节点状态,发现d-node1重新变回Ready状态。
若想去掉某个节点,可以直接 只有kubectl delete node ip 则就会直接把节点删除了。
若想把这个节点再从新加入,只需要重启节点的kubelet kube-proxy 就可以了
- kubernetes 节点维护 cordon, drain, uncordon
- 多节点Kubernetes安装
- Kubernetes部署master节点
- kubernetes多节点部署解析
- 单节点kubernetes的进程
- Centos7 单节点安装Kubernetes
- 多节点安装部署kubernetes
- ubuntu多节点安装kubernetes
- kubernetes多节点部署解析
- kubernetes多节点部署解析
- HDFS 维护节点
- 安全警戒线 security cordon
- Kubernetes高可用Master节点安装
- Kubernetes集群中部署Node节点
- 《kubernetes-1.8.0》05-node节点搭建
- kubernetes 通过annotations指定调度节点
- kubernetes跨节点共享存储cephfs
- write drain
- ubuntu 个人电脑 lnmp 环境搭建
- jstat命令详解
- KMP 模板
- java炒冷饭系列12 接口内部的类 ,从多层嵌套类中访问外部类的成员
- 总结:SDL笔记
- kubernetes 节点维护 cordon, drain, uncordon
- 你想告诉准程序员些什么?
- 概率统计笔记1
- INT_PTR 更好的移植性
- C++析构函数为什么要作为虚函数
- SQL获取本周、本月、本年时间段值
- Centos服务器安装并配置mysql,本地Navicate连接!亲测成功
- linux三剑客之sed之妙
- scala函数