kubernetes 节点维护 cordon, drain, uncordon

 这三个命令是正式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(封锁)状态意味着该节点将不再被调度新的 Pod。以下是关于设置节点cordon 状态的详细解释和步骤: 1. **什么是 Cordon**:Cordon 是一种用于标记节点的状态,表示该节点应当被暂时从调度系统中移除。当一个节点cordon 后,Kubernetes 将不会把新的 Pod 调度到这个节点上。已经在该节点上运行的 Pod 不受影响,它们会继续运行直到被手动删除或迁移。 2. **为什么要使用 Cordon**:Cordon 通常用于节点维护或升级。当你需要对一个节点进行维护或者升级操作系统时,可以先把该节点 cordon,这样新的工作负载就不会被调度到这个节点上,从而避免对正在运行的 Pod 造成影响。 3. **如何设置节点Cordon**:要设置一个节点cordon,你可以使用 `kubectl cordon` 命令后跟节点的名称。例如,假设你的节点名称是 `node-1`,你可以运行以下命令来设置该节点cordon 状态: ```shell kubectl cordon node-1 ``` 执行上述命令后,你可以使用 `kubectl get nodes` 命令来验证节点的状态。你会看到该节点的状态变为 `SchedulingDisabled`,这表示该节点已经被成功设置为 cordon 状态。 4. **恢复节点调度**:如果你完成了节点维护或升级,并希望恢复其调度功能,可以使用 `kubectl uncordon` 命令后跟节点的名称。例如: ```shell kubectl uncordon node-1 ``` 这将把节点 `node-1` 从 cordon 状态中恢复,使其可以重新接收新的 Pod 调度。 5. **注意事项**:虽然 cordon 操作会阻止新的 Pod 被调度到一个节点,但已经运行在该节点上的 Pod 不会受到影响。如果你想删除一个节点上的所有 Pod 并确保它们在其他节点上重新调度,你应该考虑使用 `kubectl drain` 命令而不是 `kubectl cordon`。 6. **示例**:假设你有一个名为 `worker-node-1` 的 Kubernetes 节点,你想将其设置为 cordon 状态以进行维护。首先,查看当前节点状态: ```shell kubectl get nodes ``` 然后,运行以下命令将 `worker-node-1` 设置为 cordon 状态: ```shell kubectl cordon worker-node-1 ``` 最后,再次运行 `kubectl get nodes` 命令来确认 `worker-node-1` 的状态已更新为 `SchedulingDisabled`。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值