0

0

K3s 集群突然大量 pod 变成 Evicted 状态怎么找触发原因

舞夢輝影

舞夢輝影

发布时间:2026-01-17 23:53:02

|

759人浏览过

|

来源于php中文网

原创

Evicted 由节点资源压力或 kubelet 配置异常触发,需依次检查 MemoryPressure/DiskPressure、kubelet 日志中的 eviction manager 提示、镜像/日志堆积情况,以及 config.yaml 中过激的 eviction-hard 设置。

k3s 集群突然大量 pod 变成 evicted 状态怎么找触发原因

直接查节点资源和 kubelet 日志,Evicted 不是随机发生的,背后一定有明确的触发信号。

先看节点有没有资源压力

Evicted 最常见原因是节点资源耗尽。重点检查三类指标:

  • 内存:运行 kubectl describe node ,看 Conditions 下是否出现 MemoryPressure True
  • 磁盘:同样在 describe node 输出里找 DiskPressure;也可登录节点执行 df -hdf -i,特别关注 /var/lib/kubelet 和容器运行时(如 /var/lib/rancher/k3s/agent/containerd)所在分区
  • inodes 耗尽:即使磁盘空间没满,df -i 显示 inode 使用率 100% 同样会触发驱逐,常见于大量小日志文件或未清理的临时镜像层

再查 kubelet 的实时行为

K3s 的 kubelet 日志是核心线索,它会明确记录“为什么驱逐”:

Teleporthq
Teleporthq

一体化AI网站生成器,能够快速设计和部署静态网站

下载
  • 在对应节点上执行:journalctl -u k3s -n 200 --no-pager | grep -i -E "(evict|pressure|failed|gc)"
  • 重点关注含 eviction managerNodeHasMemoryPressureNodeHasDiskPressureimageGC failed 的行
  • 如果看到类似 evicting pod: xxx, reason: memory usage is over threshold,就锁定了根本原因

确认是不是镜像或日志堆积导致

K3s 环境中,镜像 GC 失败或 Pod 日志无限制增长是高频诱因:

  • 检查镜像数量:crictl images | wc -l,若超千个且长期未清理,可能触发 imageGCFailed
  • 查日志目录大小:du -sh /var/lib/rancher/k3s/agent/logs/* 或挂载到节点的 emptyDirhostPath 日志路径
  • 是否有 Pod 配置了 limitRange 但没设日志轮转,导致单个容器日志涨到几十 GB

顺手验证下有没有配置异常

某些 K3s 启动参数会放大驱逐敏感度:

  • 检查 /etc/rancher/k3s/config.yaml 是否设置了过激的 eviction-hard,比如 memory.available 或 nodefs.available
  • 确认没有误删 systemd 单元文件或修改过 k3s.service 的内存限制(如 MemoryLimit=),导致 kubelet 自身被 OOM kill 后反复重启并误报压力
  • 运行 kubectl get events --sort-by=.lastTimestamp,过滤出最近 1 小时内带 EvictedNodeNotReady 的事件,看是否集中在某个节点或时间点

相关专题

更多
sort排序函数用法
sort排序函数用法

sort排序函数的用法:1、对列表进行排序,默认情况下,sort函数按升序排序,因此最终输出的结果是按从小到大的顺序排列的;2、对元组进行排序,默认情况下,sort函数按元素的大小进行排序,因此最终输出的结果是按从小到大的顺序排列的;3、对字典进行排序,由于字典是无序的,因此排序后的结果仍然是原来的字典,使用一个lambda表达式作为key参数的值,用于指定排序的依据。

387

2023.09.04

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

392

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

572

2023.08.10

Java JVM 原理与性能调优实战
Java JVM 原理与性能调优实战

本专题系统讲解 Java 虚拟机(JVM)的核心工作原理与性能调优方法,包括 JVM 内存结构、对象创建与回收流程、垃圾回收器(Serial、CMS、G1、ZGC)对比分析、常见内存泄漏与性能瓶颈排查,以及 JVM 参数调优与监控工具(jstat、jmap、jvisualvm)的实战使用。通过真实案例,帮助学习者掌握 Java 应用在生产环境中的性能分析与优化能力。

6

2026.01.20

PS使用蒙版相关教程
PS使用蒙版相关教程

本专题整合了ps使用蒙版相关教程,阅读专题下面的文章了解更多详细内容。

59

2026.01.19

java用途介绍
java用途介绍

本专题整合了java用途功能相关介绍,阅读专题下面的文章了解更多详细内容。

80

2026.01.19

java输出数组相关教程
java输出数组相关教程

本专题整合了java输出数组相关教程,阅读专题下面的文章了解更多详细内容。

38

2026.01.19

java接口相关教程
java接口相关教程

本专题整合了java接口相关内容,阅读专题下面的文章了解更多详细内容。

10

2026.01.19

xml格式相关教程
xml格式相关教程

本专题整合了xml格式相关教程汇总,阅读专题下面的文章了解更多详细内容。

13

2026.01.19

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
HTML5/CSS3/JavaScript/ES6入门课程
HTML5/CSS3/JavaScript/ES6入门课程

共102课时 | 6.8万人学习

前端基础到实战(HTML5+CSS3+ES6+NPM)
前端基础到实战(HTML5+CSS3+ES6+NPM)

共162课时 | 18.9万人学习

第二十二期_前端开发
第二十二期_前端开发

共119课时 | 12.5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号