K8s: 将一个节点移出集群和相关注意事项

这篇具有很好参考价值的文章主要介绍了K8s: 将一个节点移出集群和相关注意事项。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

前置步骤


在Kubernetes集群中,要移出一个节点,你需要执行以下步骤:

1 )将节点标记为不可调度

  • 首先,你需要将目标节点标记为不可调度,以确保Kubernetes不会在该节点上调度新的Pod
  • 这可以通过执行以下命令实现:$ kubectl cordon <node-name>
    • 其中 是你想要移出的节点的名称
    • 这个命令会将节点设置为不可调度状态
    • 这样Kubernetes就不会在这个节点上安排新的Pod了

2 ) 驱逐节点上的Pod

  • 在标记节点为不可调度之后,你需要将节点上的所有Pod驱逐到其他可用的节点上
  • 这可以通过执行以下命令完成
  • $ kubectl drain <node-name> --delete-local-data --force --ignore-daemonsets
    • 这个命令会触发Pod的正常终止过程,并将它们迁移到其他可用的节点上
    • 注意
      • --delete-local-data 标志表示允许删除节点上由Pod使用的本地数据
      • --force 标志表示强制驱逐Pod
      • --ignore-daemonsets 标志表示忽略DaemonSets管理的Pod

3 ) 从集群中移除节点

  • 一旦节点上的所有Pod都被成功驱逐到其他节点,你就可以从集群中移除该节点了
  • 这通常涉及到从集群的配置中删除节点的信息,具体的操作取决于你使用的Kubernetes部署方式(如kubeadm、Minikube、Kops等)
  • 在某些情况下,这可能涉及到在云平台上删除支持该节点的虚拟机

4 ) 验证节点移除

  • 最后,你应该验证节点是否已经从集群中成功移除

  • 可以通过执行以下命令来检查集群中的节点列表:$ kubectl get nodes

    • 如果移出的节点不再出现在列表中,那么说明节点已成功从集群中移除
  • 请注意,在执行这些操作之前,确保已经备份了所有重要的数据和配置,以防万一出现意外情况

  • 此外,如果你在生产环境中操作,请务必先在测试环境中验证所有步骤,以确保操作的正确性和安全性

后续处理

  • 执行后,发现那个节点的 STATUS 是:NotReady,SchedulingDisabled

  • 如果在执行 kubectl cordon 和 kubectl drain 命令后,节点的状态变为 NotReady,SchedulingDisabled

  • 这通常意味着节点已经被标记为不可调度(SchedulingDisabled)

  • 但尚未成功将所有Pod驱逐到其他节点或节点本身存在某些问题导致它无法进入Ready状态

  • 以下是你可以尝试的几个步骤来解决这个问题:

1 ) 检查Pod驱逐状态

  • 使用 $ kubectl get pods --all-namespaces -o wide 命令查看所有Pod的状态和它们所在的节点
  • 确保所有原本在该节点上的Pod都已经被成功驱逐到其他节点。

2 ) 检查节点事件

  • 使用 $ kubectl describe node <node-name> 命令来查看节点的详细信息
  • 特别是 Events 部分,看看是否有关于该节点为何变成 NotReady 的信息。

3 ) 检查节点日志

  • 如果可能的话,登录到该节点上,检查kubelet和其他相关组件的日志,了解为什么节点不能进入Ready状态
  • 在节点上运行如 $ journalctl -u kubelet 的命令可以查看 kubelet 的日志

4 ) 检查网络问题

  • 确保节点与Kubernetes集群的其他部分(如API服务器)之间的网络连接是正常的
  • 网络问题可能是导致节点无法就绪的常见原因。

5 ) 检查资源使用情况

  • 使用 $ kubectl top nodeskubectl top pods --all-namespaces 命令来检查节点的资源使用情况
  • 包括CPU、内存和磁盘空间。确保节点没有资源耗尽的情况。

6 ) 尝试重启kubelet

  • 有时候,简单地重启kubelet服务可以让节点恢复到正常状态
  • 使用适用于你系统的相应命令来重启kubelet(如 $ systemctl restart kubelet

7 ) 检查节点硬件和配置:

  • 如果上述步骤都没有解决问题,可能需要检查节点的硬件状态
  • 如磁盘、内存、CPU等配置,以确定是否存在硬件故障或配置错误

8 ) 手动移除节点文章来源地址https://www.toymoban.com/news/detail-855004.html

  • 如果节点确实无法恢复,并且你确定要从集群中移除它
  • 你可以使用 $ kubectl delete node <node-name> 命令来手动从集群中移除节点
  • 但是,请注意,这不会从云提供商处删除实际的虚拟机实例;你需要手动完成这一步骤(如果适用)

特别注意

  • 在进行任何操作之前,请确保你已经备份了所有重要的数据和配置,以防万一出现数据丢失或配置错误
  • 此外,如果你在生产环境中操作,请务必先在测试环境中验证所有步骤

到了这里,关于K8s: 将一个节点移出集群和相关注意事项的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • k8s集群部署 | 三节点(复用)高可用集群过程参考

    1.1.1 实验架构图 1.1.2 系统版本说明 OS 版本:CentOS Linux release 7.9.2009 (Core) 初始内核版本:3.10.0-1160.71.1.el7.x86_64 配置信息:2C2G 150G硬盘 文件系统:xfs 网络:外网权限 k8s 版本:1.25.9 1.1.3 环境基本信息 K8s集群角色 IP地址 主机名 组件信息 控制节点1(工作节点1) 192.168.204.10 k8

    2024年02月04日
    浏览(15)
  • K8S集群node节点状态为notready

    Kubernetes集群中的node节点状态显示为notready,这通常意味着该节点上的一个或多个组件出现了故障。在这种情况下,您需要进一步检查该节点的状态以确定问题的原因。您可以使用kubectl命令检查node的详细信息,例如: 此命令将显示该节点的状态,以及可能导致notready状态的任

    2024年02月15日
    浏览(8)
  • 外部节点访问 k8s 集群内的 starrocks

    用kubeadm在虚拟机搭建了k8s,按starrocks官网步骤,用k8s部署了starrocks 部署成功: 在 k8s集群内节点访问到 sr:(通过 clusterIP )  k8s 节点内访问成功: ​​​​​​​  尝试在集群外访问sr:  修改完成后查看端口 集群外部的客户端访问不了,错误是 BE 节点 not found 本地无法

    2024年02月13日
    浏览(9)
  • k8s集群—node节点的删除与添加

    在搭建集群过程中,有时候会遇到一个节点处于ready状态,另一个节点处于notready状态,需要把node节点从集群中删除后再次加入。 如果需要在k8s集群中删除节点,首先需要在master节点上删除该节点的相关数据,再删除该节点,接着在该节点上进行reset操作,接着删除相关文件

    2024年02月17日
    浏览(13)
  • k8s集群node节点运行kubectl命令

            在容器化项目部署中,某些应用需要部署到指定的机器上(涉及机器信息收集,然后生成license,机器授权等),所以需要在k8s集群的node节点上,手动执行kubectl命令。         具体的操作步骤如下: (1)在node节点执行任意kubectl命令,例如:kubectl get nodes,可以看到

    2024年02月14日
    浏览(12)
  • k8s node节点加入集群,token过期

    1、master01节点执行  kubeadm token create --print-join-command 2、执行命令 kubeadm join 192.168.0.236:16443 --token qucd8q.hsfq4a1afluzaky3 --discovery-token-ca-cert-hash sha256:92175a356db070deb2ddd3823e288e3005a4baeec9b68580dcc11ce4d3767195 3、查看node02节点是否加入集群

    2024年01月18日
    浏览(12)
  • 设置k8s中节点node的ROLES值,K8S集群怎么修改node1的集群ROLES

    其实这个Roles就是一个标签,执行以下命令给node1 和 node2 打上worker标签 k8s-node1 打上标签为worker1 k8s-node2 打上标签为worker2

    2024年02月02日
    浏览(8)
  • k8s集群Node节点管理:节点信息查看及节点label标签管理

    如果是kubeasz安装,所有节点(包括master与node)都已经可以对集群进行管理 如果是kubeadm安装,在node节点上管理时会报如下错误 只要把master上的管理文件 /etc/kubernetes/admin.conf 拷贝到node节点的 $HOME/.kube/config 就可以让node节点也可以实现kubectl命令管理 1, 在node节点的用户家目录创建

    2024年02月03日
    浏览(13)
  • K8s集群重启与恢复-Master节点启停

    1 应用场景 场景 :在实际工作中,可能某个 Master 节点需要维护,迁移,我们需要平滑的停止、启动该节点,尽量减少启停中对集群造成的影响 注意 : 为了确保 K8s 集群能够安全恢复,请在操作前对 K8s 数据进行备份 为了确保重启 Master 节点期间 K8s 集群能够使用,集群中

    2023年04月08日
    浏览(13)
  • 基于昇腾910B搭建多节点K8s集群

    自从 2013 年 Docker 诞生以来,容器一跃成为 IT 界最热门的话题。而 Kubernetes 趁着容器的东风,击败众多竞争对手,成为了“容器编排”领域的King。可以说,现在 Kubernetes 已经没有了实际意义上的竞争对手,它的地位就如同 Linux 一样,成为了事实上的云原生操作系统,是构建

    2024年01月19日
    浏览(12)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包