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
分享到:
相关推荐
前面一节重点分享了Linux的内存分配策略,基于上述的分配策略,为了规避超售的风险,Linux采了一种OOM Killer的机制,即系统可用内存(包括Swap)即将使用完之前,选择性的Kill掉一些进程以求释放一些内存
Linux系统的OOM Killer处理机制.docx
Mar 9 11:29:16 xxxxxx kernel: mysqld invoked oom-killer: gfp_mask=0x201da, order=0, oom_adj=0, oom_score_adj=0 Mar 9 11:29:16 xxxxxx kernel: mysqld cpuset=/ mems_allowed=0 Mar 9 11:29:16 x
heart_oom_protect 一个Erlang OTP库,可保护心脏免于被Linux内核的OOM Killer杀死 建造 $ rebar3 compile
1 概述 Android的设计理念之一,便是应用程序退出,但进程还会继续存在系统以便...Android基于Linux的系统,其实Linux有类似的内存管理策略——OOM killer,全称(Out Of Memory Killer), OOM的策略更多的是用于分配内存
proc <pid> oom_adj set to -17 protects the oom killer for legacy purposes.
图片oom,解决方法 图片oom,完美deom
OOM分析工具-MemoryAnalyzer JVM dump分析利器
SurfaceView加载动画 解决OOM问题 多少帧都没问题 不会卡顿 不会卡顿
主要介绍了Slave memory leak and trigger oom-killer,需要的朋友可以参考下
android解决OOM
比如:这句话是在oom_kill_process()->dump_header()函数里打印出来的,告诉你那个进程触发的这次oom killer,这里显示是in
加载大图片到内存时如何防止 OOM的产生
java jvm 中关于内存溢出分享,举例说明各种情况下可能会出现的oom事故
杀掉部分进程,释放一些内核。 大部分情况下,会杀掉导致OOM的进程,然后系统恢复。通常我们会添加对内存的监控报警,例如:当memory或swap使用超过90%时,触发报警通知,需要及时介入排查。 如果已经出现OOM,则...
用LruCache解决OOM 并且可以下载多个相同地址的图片
介绍了android开发中OOM错误的原因。