细说|Linux Out Of Memory机制
内容提要
OOM(Out Of Memory)机制是指当系统内存不足时,系统采取的应急措施。Linux内核会尝试回收可回收内存,如页缓存和延迟释放的空闲内存页。如果仍然不足,会触发OOM killer,杀掉占用内存最多的进程。OOM killer通过选择最坏的进程并调用oom_kill_process函数来实现。进程的最坏分数值是通过oom_badness函数计算的,包括进程使用的物理内存和oom_score_adj值。可以通过设置oom_score_adj值为-1000来禁止进程被OOM killer杀掉。
关键要点
-
OOM机制是指当系统内存不足时,系统采取的应急措施。
-
Linux内核会尝试回收可回收内存,如页缓存和延迟释放的空闲内存页。
-
如果内存仍然不足,内核会触发OOM killer,杀掉占用内存最多的进程。
-
OOM killer通过选择最坏的进程并调用oom_kill_process函数来实现。
-
进程的最坏分数值通过oom_badness函数计算,包括物理内存使用和oom_score_adj值。
-
可以通过设置oom_score_adj值为-1000来禁止进程被OOM killer杀掉。
-
当进程访问未映射的虚拟内存地址时,会触发缺页异常。
-
缺页异常处理会申请新的物理内存页并映射虚拟内存地址。
-
如果物理内存不足,内核会回收文件页缓存或触发swapping机制。
-
swapping机制将不常用的内存页写入交换区以缓解内存不足。
-
如果以上措施无效,内核会调用pagefault_out_of_memory()函数杀掉占用内存最多的进程。
-
out_of_memory()函数选择最坏的进程并调用oom_kill_process()杀掉它。
-
select_bad_process()函数遍历所有进程,计算最坏分数值以选择目标进程。
-
oom_badness()函数计算进程的最坏分数值,考虑进程的oom_score_adj值和物理内存使用。
-
通过设置oom_score_adj值为-1000,可以防止重要进程被OOM killer杀掉。