当前位置: 首页 > article >正文

在K8S中,节点状态notReady如何排查?

在kubernetes集群中,当一个节点(Node)的状态变为NotReady时,意味着该节点可能无法运行Pod或不能正确相应kubernetes控制平面。排查NotReady节点通常涉及以下步骤:

1. 获取基本信息

  • 使用kubectl命令行工具获取节点状态:
kubectl get nodes
  • 检查具体出现问题的节点详情:
kubectl describe node <node-name>

2. 检查事件(Event)

  • 查看节点的事件以了解与NotReady状态相关联的具体错误:
kubectl describe node <node-name> | grep -A 10 'Conditions:'

3. 条件(Conditions)分析

  • 在输出中关注Conditions不分,特别时Ready状态及其原因和消息。
  • 不同原因可能包括但不限于:
    • 网络问题:如节点与master通信中断,CNI网络插件问题等。
    • kubelet问题:kubelet进程未运行或配置错误。
    • 容器运行时问题:Docker containerd或其他容器引擎未能启动或报告错误。
    • 资源不足:磁盘空间满、内存或CPU不足等。
    • 节点健康状态探测失败:如kubelet定期向API Server汇报节点状态(通过心跳机制)出现问题

4. 具体排查步骤

  • 网络连通性:确保节点能够正常与集群中的其他组件通信。
  • kubelet服务:检查kubelet服务是否运行正常,以及日志中是否有错误信息。
systemctl status kubelet
journalctl -u kubelet -xe
  • 容器运行时:确认容器运行时服务也正在运行,并无错误。
  • 磁盘空间与资源使用:采用df -hfree -m进行检查节点的磁盘空间和系统资源使用情况。
  • 健康检查和PLEG:Kubelet有一个Pod生命周期事件Generator(PLEG),负责监测Pod的生命周期。若PLEG停滞可能会导致节点NotReady,查看kubelet的Pod状态。
  • CNI插件:确认网络插件工作正常,有时网络配置或插件故障也会导致节点NotReady。
  • 操作系统健康:检查操作系统层面是否有内核警告、硬件故障或安全组规则阻止必要的端口通信。

5. 恢复操作

  • 根据排查结果采取相应措施,例如重启Kubelet服务、清理磁盘空间、修复网络配置、更新容器运行时等。
  • 如果需要,也可以尝试将节点从集群中删除并重新加入,已出发重新初始化过程:
kubectl drain <node-name> --delete-local-data --force --ignore-daemonsets
kubectl delete node <node-name>
# 确保节点问题已解决后...
kubectl uncordon <node-name>

综上所述:
在实际环境中,排查过程需结合具体情况灵活调整,并可能深入的学习kubernetes的内部工作机制及特定版本的特性。


http://www.kler.cn/a/464025.html

相关文章:

  • QEMU网络配置简介
  • 【网络】什么是路由协议(Routing Protocols)?常见的路由协议包括RIP、OSPF、EIGRP和BGP
  • 【工具进阶】使用 Nmap 进行有效的服务和漏洞扫描
  • Node.js 中 http 模块的深度剖析与实战应用
  • k8s系列--docker拉取镜像导入k8s的containerd中
  • el-table 实现纵向多级表头
  • Java - 日志体系_Simple Logging Facade for Java (SLF4J)日志门面_SLF4J集成logback 及 原理分析
  • 探索 JMeter While Controller:循环测试的奇妙世界
  • Qt天气预报系统设计界面布局第四部分右边
  • 【玩转OCR | 腾讯云智能结构化OCR应用探索和场景实践】
  • 给vscode的新项目选择虚拟环境
  • 【漫话机器学习系列】032.代表点聚类算法(Representative-Based Clustering Algorithm)
  • STM32单片机芯片与内部57 SPI 数据手册 寄存器
  • k8s系列--通过docker拉取的镜像导入到 containerd中
  • misc-python脚本学习笔记
  • SPI通信-(STM32)
  • 机器学习代码中常用方法
  • 租用服务器还是服务器托管:哪种方案更适合您?
  • uni-app:实现普通选择器,时间选择器,日期选择器,多列选择器
  • SD-WAN组网:定义、优势与应用
  • 智能手机多源传感器融合的室内定位方法综述
  • html本地字符串处理工具|去重、分割、求交集、求并集
  • SQL 实战:联合查询与子查询 – 数据比对与关联查询优化
  • PyTorch 中 reciprocal(取倒数)函数的深入解析:分析底层实现CPP代码
  • 人工智能及深度学习的一些题目
  • 机器学习研究方向有哪些创新点