0

0

Linux kubelet 的 --fail-swap-on=false 在内存紧张环境的风险评估

舞姬之光

舞姬之光

发布时间:2026-02-20 11:11:02

|

118人浏览过

|

来源于php中文网

原创

--fail-swap-on=false 会放大oom风险,因其使kubelet忽略swap启用状态而继续运行,但内核oom killer仍工作,且cgroup无法准确统计swap内存,导致驱逐决策失准、page reclaim变慢、监控失真。

linux kubelet 的 --fail-swap-on=false 在内存紧张环境的风险评估

为什么 --fail-swap-on=false 在内存压力下会放大 OOM 风险

这个参数不是“禁用 swap”,而是让 kubelet 忽略系统启用了 swap 的事实,继续启动。但内核的 OOM killer 仍照常工作——只是它现在要面对一个更混乱的内存视图:容器内存用量被 cgroup v1/v2 统计,而 swap 页面却在全局 swap 区里游荡,cgroup 很难准确判断某个 pod 真实占用了多少可回收内存。

  • 当物理内存耗尽时,内核可能先 swap 出部分匿名页(比如 Go 程序的堆),但这些页没绑定到具体 pod 的 memory cgroup,kubelet 就无法据此做驱逐决策
  • swap 活动本身会显著拖慢 page reclaim 速度,导致 OOM killer 触发延迟变长,期间更多 pod 可能被卷入连锁崩溃
  • 某些 runtime(如 containerd + runc)在 cgroup v1 下甚至不统计 swap 使用量,kubectl top pods 显示的内存完全失真

--fail-swap-on=false 和 cgroup 版本的关系很关键

cgroup v1 基本不支持 swap accounting,启用 --fail-swap-on=false 后,kubelet 会彻底放弃对 swap 内存的感知;cgroup v2 虽支持 memory.swap.max,但默认关闭,且需内核开启 swapaccount=1 参数(现代发行版大多已弃用该参数,改用 systemd.unified_cgroup_hierarchy=1)。

  • 检查当前 cgroup 版本:stat -fc %T /sys/fs/cgroup —— 输出 cgroup2fs 表示 v2
  • 确认 swap accounting 是否生效:cat /sys/fs/cgroup/memory.max(v1 下无此文件;v2 下若存在 memory.swap.current 才算可用)
  • 即使 v2 开启了 swap accounting,kubelet 也不会用它做驱逐依据——它只看 memory.usage_in_bytes,不看 memory.swap.current

生产环境真要开 swap,得绕过 kubelet 的限制逻辑

硬设 --fail-swap-on=false 是最省事但最危险的做法。如果确实需要 swap(例如容忍短时突发、避免立即 OOM),应该让 swap 只服务于宿主机 OS 层,而非容器工作负载。

Flux AI
Flux AI

Flux AI,释放你的想象力,用文字生成图像

下载
  • 设置极低 swappiness:sysctl vm.swappiness=1,让内核只在极端缺页时才 swap
  • zram 替代磁盘 swap:压缩内存页,避免 I/O 成为瓶颈,systemctl enable systemd-zram-generator(多数新版 systemd 支持)
  • 确保所有 pod 设置 resources.limits.memory,并开启 --eviction-hard=memory.available,让 kubelet 在真正耗尽前就驱逐,别等 swap 拉胯

常见误判:以为关掉 --fail-swap-on 就等于“允许 swap”

这个 flag 只控制 kubelet 启动校验,和 swap 是否实际起作用毫无关系。swap 开不开,取决于 swapon -s 输出、/proc/swaps 内容,以及内核是否加载 swap 模块。

  • 错误现象:kubelet --fail-swap-on=false 启动成功,但 swapon -s 为空 → 实际根本没 swap,flag 白配
  • 更隐蔽的问题:swap 分区存在但被 noauto 挂载选项屏蔽,或 /etc/fstab 中 swap 行被注释 → kubelet 不报错,swap 也压根没激活
  • 验证方式永远是:free -hSwap: 行,不是看 kubelet 日志有没有报错

swap 在 Kubernetes 里从来就不是“弹性缓冲”,而是故障放大器。只要 cgroup 对 swap 的可见性不完整,任何依赖它的资源决策都会失效。这点比参数开关本身重要得多。

相关文章

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
堆和栈的区别
堆和栈的区别

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

420

2023.07.18

堆和栈区别
堆和栈区别

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

594

2023.08.10

Golang云原生微服务Kubernetes_Golang怎么集成Kubernetes开发云原生服务
Golang云原生微服务Kubernetes_Golang怎么集成Kubernetes开发云原生服务

Golang云原生微服务Kubernetes (K8s) 是指 使用 Go 语言(Golang)编写的云原生微服务,并利用 Kubernetes 平台进行容器化部署、自动化管理、弹性伸缩和高效编排的一整套现代应用架构方案。

27

2025.12.22

Golang云原生微服务Kubernetes_Golang怎么集成Kubernetes开发云原生服务
Golang云原生微服务Kubernetes_Golang怎么集成Kubernetes开发云原生服务

Golang云原生微服务Kubernetes (K8s) 是指 使用 Go 语言(Golang)编写的云原生微服务,并利用 Kubernetes 平台进行容器化部署、自动化管理、弹性伸缩和高效编排的一整套现代应用架构方案。

27

2025.12.22

磁盘配额是什么
磁盘配额是什么

磁盘配额是计算机中指定磁盘的储存限制,就是管理员可以为用户所能使用的磁盘空间进行配额限制,每一用户只能使用最大配额范围内的磁盘空间。php中文网为大家提供各种磁盘配额相关的内容,教程,供大家免费下载安装。

1520

2023.06.21

如何安装LINUX
如何安装LINUX

本站专题提供如何安装LINUX的相关教程文章,还有相关的下载、课程,大家可以免费体验。

714

2023.06.29

linux find
linux find

find是linux命令,它将档案系统内符合 expression 的档案列出来。可以指要档案的名称、类别、时间、大小、权限等不同资讯的组合,只有完全相符的才会被列出来。find根据下列规则判断 path 和 expression,在命令列上第一个 - ( ) , ! 之前的部分为 path,之后的是 expression。还有指DOS 命令 find,Excel 函数 find等。本站专题提供linux find相关教程文章,还有相关

300

2023.06.30

linux修改文件名
linux修改文件名

本专题为大家提供linux修改文件名相关的文章,这些文章可以帮助用户快速轻松地完成文件名的修改工作,大家可以免费体验。

791

2023.07.05

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

660

2026.02.13

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 9.4万人学习

Git 教程
Git 教程

共21课时 | 3.7万人学习

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

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