内核初始化期间由初始化内存分配器分配内存,完成后内存分配工作交给伙伴系统
基于伙伴系统的内存管理专注于某个结点的某个内存域,例如,DMA或高端内存域。但所有内存域和结点的伙伴系统都通过备用分配列表连接起来
也就是说内存的每个区域都有自己的伙伴系统,并且通过备用列表连接起来,比如分配普通区域内存是,伙伴系统分配失败,就使用DMA区域的伙伴系统分配内存
内存的碎片处理:
用户空间应用程序的内存一般通过页表映射,所以碎片问题一般只涉及到内核
很长时间以来,物理内存的碎片确实是Linux的弱点之一。尽管已经提出了许多方法,但没有哪
个方法能够既满足Linux需要处理的各种类型工作负荷提出的苛刻需求,同时又对其他事务影响不大。
在内核2.6.24开发期间,防止碎片的方法最终加入内核。在我讨论具体策略之前,有一点需要澄清。
文件系统也有碎片,该领域的碎片问题主要通过碎片合并工具解决。它们分析文件系统,重新排序已
分配存储块,从而建立较大的连续存储区。理论上,该方法对物理内存也是可能的,但由于许多物理
内存页不能移动到任意位置,阻碍了该方法的实施。因此,内核的