首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Linux OOM机制分析

OOM分析 oom_killer(out of memory killer)是Linux内核的一种内存管理机制,在系统可用内存较少的情况下,内核为保证系统还能够继续运行下去,会选择杀掉一些进程释放掉一些内存...一句话说明oom_killer的功能: 当系统物理内存不足时,oom_killer遍历当前所有进程,根据进程的内存使用情况进行打分,然后从中选择一个分数最高的进程,杀之取内存。...check_panic_on_oom检查系统管理员的态度,看oom时是进行oom killer还是直接panic掉,如果进行oom killer,则进入下一步; 如果系统管理员规定,谁引起oom,杀掉谁...oom_score_adj,因此系统管理时建议设置/proc//oom_score_adj,内核依然保持oom_adj设置以兼容旧版本,系统中对oom_score_adj或oom_adj中任一个进行设置...= (oom_adj*1000)/17 oom_adj=(oom_score_adj*17)/1000 当设置oom_adj=-16时,oom_score_adj自动调整为-941 当设置oom_score_adj

8.2K93
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    linux OOM killer分析

    基本概念 Linux 内核有个机制叫OOM killer(Out-Of-Memory killer),该机制会监控那些占用内存过大,尤其是瞬间很快消耗大量内存的进程,为了防止内存耗尽而内核会把该进程杀掉...oom killer机制分析 oom killer是计算出选择哪个进程kill呢?.../proc/[pid]/oom_score,当前该pid进程的被kill的分数,越高的分数意味着越可能被kill,这个数值是根据oom_adj运算后的结果,是oom_killer的主要参考。...sysctl 下有2个可配置选项: vm.panic_on_oom = 0 #内存不够时内核是否直接panic vm.oom_kill_allocating_task = 1 #oom-killer是否选择当前正在申请内存的进程进行...killer选中的概率,禁止或者给oom_adj最小或偏小的值,也可以通过sysctl调节oom killer行为 如何查看OOM日志 grep "Out of memory" /var/log/messages

    1K20

    Linux OOM一二三

    Linux开发一般会遇到“/proc/sys/vm/overcommit_memory”,即文件/etc/sysctl.conf中的vm.overcommit_memory,Overcommit的意思如同其字面意思...overcommit_memory有三种取值(注:overcommit_memory并不控制OOM,是否开启OOM由panic_on_oom控制): overcommit_memory取值 含义 0...系统是否行使OOM,由/proc/sys/vm/panic_on_oom的值决定,当/proc/sys/vm/panic_on_oom取值为1时表示关闭OOM,取值0时表示启用OOM。...如果将/proc/sys/vm/oom_kill_allocating_task的值设置为1,则OOM时直接KILL当前正在申请内存的进程,否则OOM根据进程的oom_adj和oom_score来决定。...oom_adj表示进程被OOM KILLER杀死的权重,取值“17~15”,值越大被KILL的概率越高,当进程的oom_adj值为-17时,表示永远不会被OOM KILLER选中。

    1.6K20

    linux内存不足导致tomcat宕机

    已经不在运行了 free -m 查看内存,当时那台机器free,只有77了,这张图是后在自己电脑上截的 grep "Out of memory" /var/log/messages 查看系统日志,显示内存不足...这是由于Linux 内核有个机制叫OOM killer(Out Of Memory killer),,当系统内存不足的时候,out_of_memory()被触发,然后调用select_bad_process...linux选择”bad”进程是通过调用oom_badness(),挑选的算法和想法都很简单很朴实:最bad的那个进程就是那个最占用内存的进程。 ​...对于每个进程都有一个oom_score的属性/proc/PID/oom_score oom- killer 会杀死oom_score较大的进程,当oom_score为0时禁止内核杀死该进程。...可以看到mysql的oom分数为63,java程序的oom分数为37 如何使内存不足时,不去杀我们重要的业务相关的进程?? ​

    3.2K10

    linux out of memory分析(OOM)

    原文:http://blog.csdn.net/guomsh/article/details/6536915 Linux有一个特性:OOM Killer,一个保护机制,用于避免在内存不足的时候不至于出现严重问题...,把一些无关的进程优先杀掉,即在内存严重不足时,系统为了继续运转,内核会挑选一个进程,将其杀掉,以释放内存,缓解内存不足情况,不过这种保护是有限的,不能完全的保护进程的运行。     ...在32位CPU下寻址范围是有限的,Linux内核定义了下面三个区域: # DMA: 0x00000000 - 0x00999999 (0 - 16 MB) # LowMem: 0x01000000...查看当前的oom-killer的状态:cat /proc/sys/vm/oom-kill        关闭/打开oom-killer:        echo "0" > /proc/sys/vm/oom-kill...p=430 http://www.dbanotes.net/database/linux_outofmemory_oom_killer.html http://www.sealinger.com/archives

    8.8K20

    Linux系统之 OOM 解析

    本文将聚焦于 Linux 内存结构、内存分析以及 OOM killer 等 3 个方面以及笔者多年的实践经验总结进行“吹牛逼”,当然,若吹的不好,欢迎大家扔砖、鸡蛋。...OOM,全称为 “Out Of Memory”,即 内存溢出。OOM Killer 是 Linux 自我保护的方式,防止内存不足时出现严重问题。...通常,系统内核检测到系统内存不足时,筛选并终止某个进程的过程可以参考内核源代码:linux/mm/oom_kill.c,当系统内存不足的时候,out_of_memory()被触发,然后调用 select_bad_process...Linux 操作系统选择”bad”进程是通过调用 oom_badness(),挑选的算法和想法都很简单很朴实:最 bad 的那个进程就是那个最占用内存的进程。...综上所述,本篇文章主要通过基于对 Linux 内存结构、分析及 OOM Killer 3个核心维度,从主动及被动场景等 2 方面对 Linux 操作系统内存的剖析,以探讨在实际的业务场景中,内存表现的相关活动及经验认知

    2.9K30

    LinuxOOM 终结者

    你知道的,Linux里面有许多邪恶的怪物(也叫作守护进程)。这些守护进程是由几个内核作业所看管的,其中的一个犹为恶毒。...所有的现代Linux内核中都会有一个内存不足终结者(Out of memory Killer, OOM Killer)的内建机制,在内存过低的情况下,它会杀掉你的进程。...内存超量使用的配置允许这个贪心的进程不停地申请内存,最后会触发这个内存不足的终结者,它就是来履行它的使命的。去杀掉了我们的程序,然后在大半夜把我给叫醒。...你可以在Linux下编译并运行下面这个代码片段(我是在最新的稳定版Ubuntu上运行的)。...还有别的一些方法比如OOM killer的调优,或者将负载水平分布到数个小的实例上,又或者减少应用程序的内存占用量。

    1.9K60

    程序OOM后,还能正常访问吗?

    那么请问上面linux模拟的几种情况依然可以访问,是不是oom killer被关闭了?我特地查了linux服务器的配置,并没有。...OOM Killer 是内核中的一个进程,当系统出现严重内存不足时,它就会启用自己的算法去选择某一个进程并杀掉....OOM,全称为 “Out Of Memory”,即内存溢出。OOM Killer 是 Linux 自我保护的方式,防止内存不足时出现严重问题。...通常,系统内核检测到系统内存不足时,筛选并终止某个进程的过程可以参考内核源代码:linux/mm/oom_kill.c,当系统内存不足的时候,out_of_memory()被触发,然后调用 select_bad_process...当然,对一个进程来说,内存的使用受多种因素的限制,可能在系统内存不足之前就达到了rlimit和memory cgroup的限制,同时它还可能受不同编程语言所使用的相关内存管理库的影响,就算系统处于内存不足状态

    18800

    细说|Linux Out Of Memory机制

    什么是OOM机制 OOM 是 Out Of Memory 的缩写,中文意思是内存不足。而 OOM机制 是指当系统内存不足时,系统触发的应急机制。...当 Linux 内核发现系统中的物理内存不足时,首先会对系统中的可回收内存进行回收,能够被回收的内存有如下: 读写文件时的页缓存。 为了性能而延迟释放的空闲 slab 内存页。...当系统内存不足时,内核会优先释放这些内存页。因为使用这些内存页只是为了提升系统的性能,释放这些内存页也不会影响系统的正常运行。 如果释放上述的内存后,还不能解决内存不足的情况,那么内核会如何处理呢?...OOM killer 实现 接下来,我们分析一下内核是如何实现 OOM killer 的。 由于在 Linux 系统中,进程申请的都是虚拟内存地址。...最后加上进程的 OOM 建议值,得出最终的分数值。 通过 oom_badness() 函数计算出进程的最坏分数值后,系统就能从中选择一个分数值最大的进程杀死,从而解决内存不足的情况。

    2.8K20

    oom killer

    Linux系统内存管理中存在着一个称之为OOM killer(Out-Of-Memory killer)的机制,该机制主要用于内存监控,监控进程的内存使用量,当系统的内存耗尽时,其将根据算法选择性地kill...基于上面的多种尝试内存分配仍然失败的情况,将会调用__alloc_pages_may_oom()触发OOM killer机制。...()检查是否报linux内核panic;继而判断sysctl_oom_kill_allocating_task变量及进程检查,如果符合条件判断,则将当前分配的内存kill掉;否则最后,将通过select_bad_process...顺便研究一下oom_badness()的实现: 【file:/ mm/oom_kill.c】 /** * oom_badness - heuristic function to determine which...points : 1; } 计算进程分值的函数中,首先排除了不可OOM kill的进程以及oom_score_adj值为OOM_SCORE_ADJ_MIN(即-1000)的进程,其中oom_score_adj

    1.9K20

    从vector扩容看STL空间分配器的本质

    代码在windows和linux结果如下: 图1 windows和linux对比图 如上,左图是windows上运行结果,右图为linux运行结果,vector每次进行空间扩展时,windows是按照临界值的...1.5倍左右进行,linux是按照2的倍数进行扩展。...原因主要有两点: 当new无法申请足够的空间抛出异常前需要先调用异常处理函数,这种处理的机制也叫做new-handle机制,但内存不足的异常处理通常被认为是客户端需要处理的。...private: static void *oom_malloc(size_t); // 分配不足 static void *oom_realloc(void...C语言的函数外,在空间分配不足时还是用了下面两个函数: static void *oom_malloc(size_t); // 分配不足 static void *oom_realloc

    97120

    记录一次应用被突然kill掉的问题定位经历

    问题背景:一次启动本地应用,两分钟过后自动退出,通过日志并未发现任何异常状况,莫名其妙的应用就自动被杀掉了; 解决思路: 1、linux通过top查看java应用内存和cpu都不高,只是过一会突然就没了...Killed process 182650 (java) total-vm:16705124kB, anon-rss:2079844kB, file-rss:22020kB 以上信息可以看到内存溢出被linux...但是我应用内存占用并不是特别高,通过jinfo -flags 发现java应用的启动预申请内存达到了10G; image.png 5、通过free或者vmstat查看剩余内存大小只有10G了,内核检测到系统内存不足...、挑选并杀掉某个进程的过程可以参考内核源代码 linux/mm/oom_kill.c,当系统内存不足的时候,out_of_memory() 被触发,然后调用 select_bad_process() 选择一个...-1000 到 1000范围区间,设置举例:当某一个应用内存申请占用1G时,设置oom_score_adj=-500时,实际linux会认为该应用只用了500M,会有个打折机制;以确保某些重要应用不会被意外

    2.3K80

    记录一次java应用突然挂掉的问题定位

    问题背景:一次启动本地应用,两分钟过后自动退出,通过日志并未发现任何异常状况,莫名其妙的应用就自动被杀掉了; 1、linux通过top查看java应用内存和cpu都不高,只是过一会突然就没了; 2、通过应用日志并未查到有任何异样...Killed process 182650 (java) total-vm:16705124kB, anon-rss:2079844kB, file-rss:22020kB 以上信息可以看到内存溢出被linux...但是我应用内存占用并不是特别高,通过jinfo -flags 发现java应用的启动预申请内存达到了10G; 5、通过free或者vmstat查看剩余内存大小只有10G了,内核检测到系统内存不足...、挑选并杀掉某个进程的过程可以参考内核源代码 linux/mm/oom_kill.c,当系统内存不足的时候,out_of_memory() 被触发,然后调用 select_bad_process() 选择一个...我们可以在用户空间通过操作每个进程的 oom_adj 内核参数来决定哪些进程不这么容易被 OOM killer 选中杀掉。

    1.1K30

    记一次生产服务器进程突然消失问题排查!

    journalctl -k | grep -i -e memory -e oom 执行上面的命令,可以初步排查出,消失的进程是否是触发了 Linux 系统的 OOMKiller。...pages RAM 0 pages HighMem 3673 pages reserved 67960 pages shared 124940 pages non-shared 这些日志信息显示对应进程触发 Linux...产生的原因通常是因为某时刻应用程序大量请求内存导致系统内存不足造成的,这会触发 OOM killer,进而会杀掉某个进程以腾出内存留给系统用,不致于让系统立刻崩溃。...OOM killer Linux 内核根据应用程序的要求分配内存,通常来说应用程序分配了内存但是并没有实际全部使用,为了提高性能,这部分没用的内存可以留作它用,这部分内存是属于每个进程的,内核直接回收利用的话比较麻烦...内核检测到系统内存不足、挑选并杀掉某个进程的过程可以参考内核源代码 linux/mm/oom_kill.c,当系统内存不足的时候,out_of_memory() 被触发,然后调用 select_bad_process

    2.1K20
    领券