[LINUX-06-1]Linux内存回收机制

Posted 柒月

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了[LINUX-06-1]Linux内存回收机制相关的知识,希望对你有一定的参考价值。

分析1:

1 回收两原因

内核之所以要进行内存回收,主要原因有两个:

  1. 内核需要为任何时刻突发到来的内存申请提供足够的内存,以便cache的使用和其他相关内存的使用不至于让系统的剩余内存长期处于很少的状态。
  2. 当真的有大于空闲内存的申请到来的时候,会触发强制内存回收。

2 回收两目标

一种是针对zone的,另一种是针对一个memcg的;

3 对于zone

内存回收方式分为三种,分别是快速内存回收、直接内存回收、kswapd内存回收。

  1. 快速内存回收:处于get_page_from_freelist()函数中,在遍历zonelist过程中,对每个zone都在分配前进行判断,如果分配后zone的空闲内存数量 < 阀值 + 保留页框数量,那么此zone就会进行快速内存回收。其中阀值可能是min/low/high的任何一种,因为在快速内存分配,慢速内存分配和oom分配过程中如果回收的页框足够,都会调用到get_page_from_freelist()函数,所以快速内存回收不仅仅发生在快速内存分配中,在慢速内存分配过程中也会发生。
  2. 直接内存回收:处于慢速分配过程中,直接内存回收只有一种情况下会使用,在慢速分配中无法从zonelist的所有zone中以min阀值分配页框,并且进行异步内存压缩后,还是无法分配到页框的时候,就对zonelist中的所有zone进行一次直接内存回收。注意,直接内存回收是针对zonelist中的所有zone的,它并不像快速内存回收和kswapd内存回收,只会对zonelist中空闲页框不达标的zone进行内存回收。在直接内存回收中,有可能唤醒flush内核线程。
  3. kswapd内存回收:发生在kswapd内核线程中,每个node有一个swapd内核线程,也就是kswapd内核线程中的内存回收,是只针对所在node的,并且只会对分配了order页框数量后空闲页框数量 < 此zone的high阀值 + 保留页框数量的zone进行内存回收,并不会对此node的所有zone进行内存回收。

 

 

分析2:

 

 

 

 

 

 

 

 

原文:https://www.jianshu.com/p/7ab51b8a6368

 

以上是关于[LINUX-06-1]Linux内存回收机制的主要内容,如果未能解决你的问题,请参考以下文章

linux内存回收机制

Linux内存回收机制lru

内存回收机制lru

Python 的内存管理机制

Android 内存回收机制

Linux内存回收机制watermark