如何在Linux中禁用oom Killer?[关闭]

我当前的配置是:

> cat /proc/sys/vm/panic_on_oom

0

> cat /proc/sys/vm/oom_kill_allocating_task

0

> cat /proc/sys/vm/overcommit_memory

1

但是当我执行任务时,它还是被杀死了。

> ./test/mem.sh

Killed

> dmesg | tail -2

[24281.788131] Memory cgroup out of memory: Kill process 10565 (bash) score 1001 or sacrifice child

[24281.788133] Killed process 10565 (bash) total-vm:12601088kB, anon-rss:5242544kB, file-rss:64kB

回答:

我的任务习惯于科学计算,这会花费很多记忆,看来这overcommit_memory=1可能是最佳选择。

回答:

实际上,我正在从事一个数据分析项目,该项目花费的内存多于16G,但是我被要求将其限制在左右5G。通过优化程序本身来实现此要求可能是不可能的,因为该项目使用许多子命令,并且其中大多数不包含Java

XmsXmxJava 中的选项。

回答:

我的项目应该是一个过度使用的系统。就像所说的那样,似乎我的应用程序更喜欢xmalloc在mem分配失败时崩溃。

> cat /proc/sys/vm/overcommit_memory

2

> ./test/mem.sh

./test/mem.sh: xmalloc: .././subst.c:3542: cannot allocate 1073741825 bytes (4295237632 bytes allocated)

我不想投降,尽管如此多的考验使我筋疲力尽。所以,请给我看看通往光明之路; )

回答:

OOM杀手不会消失。如果没有记忆,则必须付费。您可以做的是设置一个限制,在此限制之后内存分配将失败。这正是vm.overcommit_memory2实现的设置。

从文档:

Linux内核支持以下过量使用处理模式

2-不要过度使用。不允许为系统分配的总地址空间超过swap

+物理RAM的可配置量(默认为50%)。在大多数情况下,这取决于您使用的数量,这意味着进程在访问页面时不会被杀死,但是会在适当的分配内存时收到错误。

通常,内核会很乐意分发虚拟内存(过量使用)。仅当您引用页面时,内核才必须将页面映射到真实的物理框架。如果无法满足该请求,则需要由OOM杀手杀死一个进程以腾出空间。

禁用过量使用意味着如果内核无法提交所请求的内存量,eg

malloc(3)将返回NULL。这使事情更具可预测性,尽管有局限性(许多应用程序分配的资源超出了他们的需要)。

以上是 如何在Linux中禁用oom Killer?[关闭] 的全部内容, 来源链接: utcz.com/qa/436163.html

回到顶部