内核 oom 分数是如何计算的?

内核 oom 分数是如何计算的?

在 Google 上查找,找不到任何解释如何proc/<pid>/oom_score计算分数的内容。为什么要使用这个分数,而不是只使用总内存使用量?

答案1

参见 Goldwyn Rodrigues 的2009 年文章当时的实施,Jonathan Corbet 的2010 年文章我认为目前的行为,以及乔纳森·科贝特的2013 年文章了解关于未来变革的想法。

摘自2010年的文章:

在 David 的补丁集中,旧的 badness() 启发式方法几乎完全消失了。相反,计算变成了一个简单的问题,即进程使用了​​多少百分比的可用内存。如果整个系统内存不足,则“可用内存”是系统可用的所有 RAM 和交换空间的总和。相反,如果 OOM 情况是由于耗尽给定 cpuset/控制组允许的内存而导致的,则“可用内存”是分配给该控制组的总内存量。如果超出了内存策略施加的限制,则会进行类似的计算。在每种情况下,进程的内存使用量都被视为其驻留集(它正在使用的 RAM 页数)和交换使用量的总和。

此计算结果为一个百分比乘以十的数字;使用可用内存的每个字节的进程将获得 1000 分,而完全不使用内存的进程将获得零分。此分数几乎没有启发式调整,但代码仍然从 root 拥有的进程的分数中减去少量 (30),因为它们比用户拥有的进程略有价值。

另一个应用的调整是添加存储在每个进程的 oom_score_adj 变量中的值,该值可以通过 /proc 进行调整。此旋钮允许调整每个进程对用户空间中 OOM 终止程序的吸引力;将其设置为 -1000 将完全禁用 OOM 终止程序,而将其设置为 +1000 则相当于在相关进程上绘制一个大目标。

相关内容