有关OOM KILLER的一些理解
2012-07-30 15:52
211 查看
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 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 KILLER的一些理解
- 有关JavaScript中call()和apply() 的一些理解
- 有关基于模型的设计(MBD)一些概念和理解(zz)
- 有关数据库事务的一些理解-原生的Java的JDBC事务
- 有关OOM的一些处理
- 有关DDS的一些初步理解:相位噪声和无杂散动态范围
- 有关catalog的一些理解
- 有关正则匹配简单运用的一些理解1
- 有关数据库事务的一些理解-MySQL本身的事务
- 有关json的一些理解
- 有关反射的一些理解
- 有关在matlab中对信号采样及频谱的一些解释;复数的频谱,高分辨率谱,高密度谱的一些理解
- js中有关滑动问题的一些理解
- 有关BCD码,ASCII码的一些理解
- 有关PHP函数:array_diff()与array_diff_assoc()的一些理解点
- 有关数据库事务的一些理解
- linux中有关环境变量的一些理解
- 有关网络协议融合、存储关键知识点的一些理解
- 有关在matlab中对信号采样及频谱的一些解释;复数的频谱,高分辨率谱,高密度谱的一些理解
- 有关socket网络编程中一些概念的理解