0

0

oom_score_adj 无效的 cgroup v1 vs v2 memory controller 迁移坑

冷漠man

冷漠man

发布时间:2026-01-30 13:56:54

|

258人浏览过

|

来源于php中文网

原创

oom_score_adj写入后未生效的根本原因是cgroup v2已启用而操作仍按v1设计:必须先将进程移入目标cgroup,再写入该cgroup内才有效,否则仅作用于默认root cgroup且不参与OOM决策。

oom_score_adj 无效的 cgroup v1 vs v2 memory controller 迁移坑

为什么 oom_score_adj 写入后没生效?

直接写 /proc/$PID/oom_score_adj 看似成功,但进程仍被误杀,根本原因常是 cgroup v2 已启用,而你的操作逻辑还按 v1 设计。cgroup v2 下,oom_score_adj 的作用范围被严格限制在 leaf cgroup 内,且仅对该 cgroup 内的 direct children 进程有效;父 cgroup 的设置不继承,更不会影响已存在的、未被显式移动进该 cgroup 的进程。

cgroup v1 和 v2 对 memory.oom_controloom_score_adj 的处理差异

v1 中:memory.oom_control 是开关,配合 oom_score_adj 共同决定是否触发 OOM killer;v2 废弃了 memory.oom_control,改用 memory.low / memory.high / memory.max 分级管控,并把 OOM 判定逻辑下沉到内核 memory controller,oom_score_adj 仅用于同一 cgroup 内多个进程间的相对优先级排序,不再参与“是否该 OOM”的决策。

  • v1:可全局调优单个进程的 OOM 抵抗力,靠 oom_score_adj 偏移值
  • v2:必须先将进程 move 到目标 cgroup(如 /sys/fs/cgroup/memory/myapp/),再写 oom_score_adj,否则写入无效或被忽略
  • v2 中若 cgroup 设置了 memory.max 为有限值,且内存超限,内核会直接 kill 该 cgroup 中任意一个进程(选 oom_score_adj 最低者),不查全局 /proc/*/oom_score_adj

迁移时最常踩的三个坑

从 v1 迁移到 v2,光改路径不够,行为逻辑已变。

Grokipedia
Grokipedia

xAI推出的AI在线百科全书

下载
  • 误以为 echo -1000 > /proc/$PID/oom_score_adj 仍能保命 —— v2 下它只在进程所属 cgroup 内起相对作用,无法覆盖 cgroup 级别的内存硬限
  • 忘记将进程 move 到目标 cgroup:echo $PID > /sys/fs/cgroup/memory/myapp/cgroup.procs 缺失,导致 oom_score_adj 写入的是默认 root cgroup,完全不生效
  • 混用 v1/v2 挂载点:系统启用了 v2(mount | grep cgroup 显示 type cgroup2),但脚本还在读写 /sys/fs/cgroup/memory/xxx/ 下的 v1 接口(如 memory.limit_in_bytes),这些文件已不存在或返回 ENOENT

验证 oom_score_adj 是否真在起作用

不能只看写入是否成功,要确认进程当前归属的 cgroup 及其 memory 控制策略。

  • 查进程所在 cgroup:cat /proc/$PID/cgroup | grep memory,确认输出类似 0::/myapp(v2)而非 memory:/myapp(v1)
  • 查该 cgroup 是否设了 memory.maxcat /sys/fs/cgroup/myapp/memory.max,若为 max 表示无硬限,若为数值(如 512M),OOM 就由它触发,oom_score_adj 仅影响 kill 顺序
  • 对比同 cgroup 内多进程的 oom_score_adj 值:for p in $(cat /sys/fs/cgroup/myapp/cgroup.procs); do echo "$p $(cat /proc/$p/oom_score_adj 2>/dev/null)"; done | sort -k2n,观察排序是否符合预期

真正关键的不是调高某个进程的分数,而是确保它在正确的 cgroup 里、且该 cgroup 的 memory.max 设置合理。否则 oom_score_adj 就像给即将沉船的乘客调换舱位。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

237

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

458

2024.03.01

sort排序函数用法
sort排序函数用法

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

395

2023.09.04

硬盘接口类型介绍
硬盘接口类型介绍

硬盘接口类型有IDE、SATA、SCSI、Fibre Channel、USB、eSATA、mSATA、PCIe等等。详细介绍:1、IDE接口是一种并行接口,主要用于连接硬盘和光驱等设备,它主要有两种类型:ATA和ATAPI,IDE接口已经逐渐被SATA接口;2、SATA接口是一种串行接口,相较于IDE接口,它具有更高的传输速度、更低的功耗和更小的体积;3、SCSI接口等等。

1135

2023.10.19

PHP接口编写教程
PHP接口编写教程

本专题整合了PHP接口编写教程,阅读专题下面的文章了解更多详细内容。

213

2025.10.17

php8.4实现接口限流的教程
php8.4实现接口限流的教程

PHP8.4本身不内置限流功能,需借助Redis(令牌桶)或Swoole(漏桶)实现;文件锁因I/O瓶颈、无跨机共享、秒级精度等缺陷不适用高并发场景。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1893

2025.12.29

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

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

21

2026.01.19

C++ 设计模式与软件架构
C++ 设计模式与软件架构

本专题深入讲解 C++ 中的常见设计模式与架构优化,包括单例模式、工厂模式、观察者模式、策略模式、命令模式等,结合实际案例展示如何在 C++ 项目中应用这些模式提升代码可维护性与扩展性。通过案例分析,帮助开发者掌握 如何运用设计模式构建高质量的软件架构,提升系统的灵活性与可扩展性。

8

2026.01.30

c++ 字符串格式化
c++ 字符串格式化

本专题整合了c++字符串格式化用法、输出技巧、实践等等内容,阅读专题下面的文章了解更多详细内容。

8

2026.01.30

热门下载

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

精品课程

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

共578课时 | 53.3万人学习

国外Web开发全栈课程全集
国外Web开发全栈课程全集

共12课时 | 1.0万人学习

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

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