oom详解
发布日期:2021-09-16 04:36:40
浏览次数:21
分类:技术文章
本文共 2194 字,大约阅读时间需要 7 分钟。
目录
oom_adj是什么
oom_adj 是一个打分因子, 取值范围 -17到 15。 取值 -17 这个进程就永远杀不掉了
oom_score_adj是什么
oom_score_adj 也是一个打因子,取值范围 -1000 到 1000。取值 -1000 这个进程也是永远杀不掉。
oom_adj和oom_score_adj关系
在内核里表现其实只有oom_score_adj,那 oom_adj有什么用呢? 当写入oom_adj时会通过oom_adj这个系数计算出oom_score_adj。
计算流程:
if (oom_adj == OOM_ADJUST_MAX) 如果 oom_adj 是 -17 则 oom_adj = -1000 oom_adj = OOM_SCORE_ADJ_MAX;else oom_adj = (oom_adj * OOM_SCORE_ADJ_MAX) / -OOM_DISABLE; 否则 oom_adj 等于 (oom_ajd * 1000)/17, 这个直接就是整型的除法,去掉小数了,会导致输入和输出可能不一致,后面有讲到if (oom_adj < task->signal->oom_score_adj && !capable(CAP_SYS_RESOURCE)) { 在这里判断下权限,如果oom_adj小于上次的值,会判断当前用户的权限。 err = -EACCES; 如果是非root用户,则直接返回没有 EACCESS,表示没有权限 goto err_sighand;}task->signal->oom_score_adj = oom_adj; 把上面算到的oom_adj 赋值给 oom_score_adj
为什么写入的oom_adj和获取的oom_adj不一致:
这个要看到oom_adj是如何读取的
if (task->signal->oom_score_adj == OOM_SCORE_ADJ_MAX) 如果oom_score_adj == 1000, oom_adj直接等于 15 oom_adj = OOM_ADJUST_MAX;else oom_adj = (task->signal->oom_score_adj * -OOM_DISABLE) / 否则 oom_adj = oom_score_adj * 17 / 1000 OOM_SCORE_ADJ_MAX; 之前的oom_score_adj = (oom_adj * 1000) / 17 看这两个基本就是反转的关系,但是因为是整型除,并且oom_adj没有17的倍数,所以基本上只要输入一个oom_adj,在输出的oom_adj都会减了,但是不会影响oom_score_adj.
通过以上分析,oom_adj有减少不要奇怪,关注oom_score_adj就好了。
进程如何打分
打分points,主要是badness。
adj = (long)p->signal->oom_score_adj;if (adj == OOM_SCORE_ADJ_MIN) { oom_score_adj == -1000 则直接 返回 0,及打分为0,分数等于0基于上就是不会被OOM task_unlock(p); return 0;}points = get_mm_rss(p->mm) + atomic_long_read(&p->mm->nr_ptes) + get_mm_counter(p->mm, MM_SWAPENTS);points = 驻留内存 + 进程占用的page数+占用的swap内存task_unlock(p);/* * Root processes get 3% bonus, just like the __vm_enough_memory() * implementation used by LSMs. */if (has_capability_noaudit(p, CAP_SYS_ADMIN)) 如果是root用户,则 points 减去 3%。 points -= (points * 3) / 100;/* Normalize to oom_score_adj units */points += adj; oom_score_adj 会加到 points上
通过以上代码可以确定给每个进程打分取决于,驻留内存, pagetable和swap的使用,
root用户的进程会减去3%的分数
oom_score_adj 最终会加到打分的上面去。
oom怎么判断
遍历所有进程,判断哪个得分最高,就杀掉。
oom 不同的linux差不多,有个别小项可能不一样。 以上代码基于 3.10.0-32
转载地址:https://blog.csdn.net/wllabs/article/details/103916169 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!
发表评论
最新留言
感谢大佬
[***.8.128.20]2024年04月03日 04时11分16秒
关于作者
喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
SpringMVC常用的注解有哪些?
2019-04-26
spring bean的生命周期
2019-04-26
计算机网络子网划分详解
2021-06-29
计算机网络生成树算法STP简介
2021-06-29
三郎数据结构算法学习笔记:哈希表查找
2021-06-29
三郎数据结构算法学习笔记:二叉树的三种遍历及增删改查
2021-06-29
三郎数据结构算法学习笔记:顺序存储二叉树
2021-06-29
三郎数据结构算法学习笔记:线索二叉树
2021-06-29
解释Spring支持的几种bean的作用域。
2021-06-29
Spring框架中都用到了哪些设计模式?
2019-04-26
什么是MyBatis?
2019-04-26
MyBatis的优点和缺点
2019-04-26
#{}和${}的区别是什么?
2019-04-26
LeetCode题解(1508):子数组和排序后的区间和(Python)
2019-04-26
LeetCode题解(1509):三次操作后最大值与最小值的最小差(Python)
2019-04-26
LeetCode题解(1510):石子游戏IV(Python)
2019-04-26
LeetCode题解(1497):检查数组对是否可以被k整除(Python)
2019-04-26
LeetCode题解(0781):森林中的兔子(Python)
2019-04-26
LeetCode题解(0930):和相同的二元子数组(Python)
2019-04-26
LeetCode题解(0939):最小面积矩形(Python)
2019-04-26