`
shuechaolau
  • 浏览: 34318 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

有关OOM KILLER的一些理解

 
阅读更多

Linux下有一种OOM KILLER 的机制,它会在系统内存耗尽的情况下,启用自己算法有选择性的kill 掉一些进程。

一、为什么会有OOM killer

      当我们使用应用时,需要申请内存,即进行malloc的操作,进行malloc操作如果返回一个非NULL的操作表示申请到了可用的内部你。事实上,这个地方是可能存在bug的。Linux有一种内存优化机制,即:允许程序申请比系统可用内存更多的内存(术语:overcommit),但是Linux并不保证这些内存马上可用,如果凑巧你申请到的内存中在你需要使用的时候还没有完全释放出来,这个时候就会触发OOM killer了。内核代码为:mm/oom_kill.c,其调用顺序为:

malloc -> _alloc_pages -> out_of_memory() -> select_bad_process() -> badness()

 

二、如何选择要kill掉的进程

重点分析badness代码,可以参考附件代码,我看了个大概:

1)计算该进程以及其子进程所占用的内存;

2)计算CPU时间和存活时间

3)做相应的权重调整

总结起来,就是占用内存越高,得分越高,cpu时间和存活时间越高,得分越低;进程优先级越高,得分越低

综合上述因素后,会得到一个point的值,得分最高的会被选中,然后被kill掉。

 

系统日志文件相关:

/var/log/messages

 

/proc/pid/oom_score

/proc/pid/oom_adj

  • OOM.rar (2.1 KB)
  • 下载次数: 17
分享到:
评论

相关推荐

    MySQL OOM 系统二 OOM Killer

    在Linux系统中,当内存资源紧张,即将耗尽时,为避免系统崩溃,Linux内核引入了一种称为OOM (Out Of Memory) Killer的机制。OOM Killer会选择性地杀死某些进程以回收内存。这一机制主要针对系统可用内存(包括Swap...

    heart_oom_protect:Erlang库可保护心脏免受Linux内核的OOM Killer的杀害

    当Linux系统面临内存不足的压力时,内核会启动一个称为“Out-of-Memory (OOM) Killer”的机制来防止系统崩溃。然而,OOM Killer可能会选择终止重要的进程,包括Erlang应用程序。针对这种情况,有一个名为“heart_oom...

    lab8_oom实验说明1

    《理解Linux OOM Killer机制:从lab8_oom实验入手》 Linux操作系统的OOM (Out-Of-Memory) Killer是一个重要的内存管理机制,用于处理系统内存不足的情况。当系统资源极度紧张,无法分配新的内存时,OOM Killer会...

    oom.rar_legacy

    标题“oom.rar_legacy”暗示了我们正在探讨与操作系统内存管理中的“Out of Memory”(OOM) killer相关的遗留问题。在Linux系统中,当系统内存不足时,OOM killer会被触发,它会选择并终止某些进程以回收内存,从而...

    安卓内存OOM分析

    如果一个应用持续占用大量内存,系统为了保护整体稳定性和用户体验,可能会触发OOM Killer,选择性地杀死一些内存占用高的进程。 **内存泄露分析:** 内存泄露是导致OOM的常见原因之一。当一个对象不再使用但仍然被...

    Android LMK机制简介

    虽然Linux的oom killer能够应对大多数低内存情况,但在Android这种高度定制化的环境中,oom killer存在一些明显的局限性: - **响应速度慢**:oom killer通常在内存极度紧张时才会被触发,此时可能已经对用户体验...

    MySQL OOM 系列三 摆脱MySQL被Kill的厄运

    2. **调整OOM_adj参数**:通过调整MySQL进程的OOM_adj值,可以降低其在OOM Killer选择中的优先级。数值越小,进程越不容易被Kill。不过,这并不意味着MySQL就不会被Kill,只是降低了概率。 3. **加强内存监控与报警...

    Android-OOM.rar_memory android_memory for Android_out

    - Logcat日志:查找“dalvikvm-heap”或“Low Memory Killer”相关的错误信息。 - ANR(Application Not Responding):长时间执行主线程任务,导致系统认为应用无响应,也会显示OOM。 **4. 解决策略** - 对象复用...

    MySQL OOM 系列一 Linux内存分配

    当系统内存(包括Swap)即将耗尽时,OOM Killer会选择性地杀死一些进程以释放内存。这通常是最后的手段,因为杀死进程可能会导致数据丢失和服务中断。 在后续章节中,我们将深入探讨Linux OOM Killer的工作机制,...

    深入理解LINUX内核(中文第三版)第八章 内存管理2

    8. **内存压力与OOM Killer**:当系统面临内存压力时,Linux内核会触发Out-of-Memory (OOM) killer,选择并终止一些进程以释放内存,防止系统崩溃。 9. **内存故障恢复**:内核还包含错误检测和处理机制,如对内存...

    Android内核驱动——内存管理

    ### Android内核驱动——内存管理:深入理解LowMemoryKiller机制 #### 一、LowMemoryKiller概述 在深入探讨LowMemoryKiller之前,我们先了解下它的背景和作用。LowMemoryKiller(低内存杀手)是Android内核中一种...

    《深入理解linux内存管理》学习笔记 Linux 高阶学习

    6. **内存压榨(OOM,Out-Of-Memory)**:当系统完全耗尽内存时,内核会触发OOM killer,选择并终止某些进程以释放内存。了解OOM的工作原理和避免策略对于系统稳定至关重要。 7. **内存泄漏检测**:程序运行过程中...

    Understanding The Linux Virtual Memory Manager.rar

    oom killer在系统面临内存耗尽时,会选择杀死一些低优先级的进程,以保障关键服务的正常运行。 总的来说,理解Linux虚拟内存管理对于系统管理员、内核开发者和性能优化工程师至关重要。通过深入学习这一主题,我们...

    嵌入式开发经验:Android系统的内存管理研究

    而OOM Killer机制则是当系统内存耗尽时,内核会选择性地杀死一些进程以释放内存,它通过一系列策略和标准来决定哪些进程会被终止。 Android在继承Linux内存管理的基础上,进行了特定的优化和调整以适应移动设备的...

    深入理解linux内核中文第三版--第8章

    8. **内存压力和OOM killer**:当系统面临严重内存压力时,Linux会启动Out-Of-Memory (OOM) killer,选择并终止某些进程以释放内存,防止系统崩溃。 9. **物理内存的预留和保留**:内核为关键系统组件预留一部分...

    深入理解linux内核 Understanding the linux kerne

    2. **内存管理**:深入解析虚拟内存系统,包括页表、页面替换算法(如LRU、OOM killer)、内存分配器(如slab分配器)以及内存映射机制。 3. **中断和异常处理**:学习中断的基本概念,包括软硬件中断、中断处理...

    JAVA进程突然消失问题解决方案

    再者,虽然较为罕见,但Java进程的消失也可能与JVM的Out-Of-Memory (OOM) 异常有关。通常,JVM在遇到OOM时会尝试进行垃圾收集以释放内存,而不是直接退出。然而,在极端情况下,如内存泄漏,内存持续增长直至超出...

Global site tag (gtag.js) - Google Analytics