news 2026/4/23 22:02:28

Buddy分配器

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Buddy分配器

Buddy分配器

1. 内核在基本的伙伴分配器基础改进扩展

支持内存节点和区域,称为分区的伙伴分配器(zoned buddy allocator)。
为了预防内存碎片,把物理页框通过移动性分组。
针对分配单页做了性能优化,为了减少处理器锁的竞争,在内存区域增加了1个每处理器页集合。

2. 分区的伙伴分配器源码分析

2.1 数据结构

#defineMAX_ORDER11// MAX_ORDER是最大阶数,实际上最大可分配的是最大阶数加1,默认值是11,意味着伙伴分配器一次最多可以分配2^10页。structfree_area{structlist_headfree_list[MIGRATE_TYPES];// 不同类型的空闲区域unsignedlongnr_free;};structzone{/* ... */structfree_areafree_area[MAX_ORDER];/* ... */};

2.2 根据分配标志获取首选区域类型

内核使用GFP_ZONE_TABLE定义了标志组合到区域类型的映射表。其中GFP_ZONES_SHIFT是区域类型占用的位数。GFP_ZONE_TABLE把每种标志组合映射到32位整数的某个位置,偏移是(标志组合 * 区域类型位数),从这个偏移开始的GFP_ZONES_SHIFT个二进制位存放区域类型。

3. 备用区域列表 (Zonelist)

借用必须遵守规则:
一个内存节点的某个区域类型可以从另一个内存节点的相同区域类型借用物理页,比如节点0的普通区域可以从节点1的普通区域借用物理页。
高区域类型可以从低区域类型借用物理页,比如普通区域可以从DMA区域借用物理页。
低区域类型不能从高区域类型借用物理页,比如DMA区域不能从普通区域借用物理页。

包含所有内存节点的备用区域列表有两种排序方法:

  1. 节点优先顺序:先根据节点距离从小到大排序,然后在每个节点里面根据区域类型从高到低排序。优点是优先选择距离近的内存,缺点是在高区域耗尽以后使用低区域。
  2. 区域优先顺序:先根据区域类型从高到低排序,然后在每个区域类型里面根据节点距离从小到大排序。优点是减少低区域耗尽的几率,缺点是不能保证优先选择距离近的内存。

默认的排序方法就是自动选择最优的排序方法:比如是64位系统,因为需要DMA和DMA32区域的备用相对少,所以选择节点优先顺序;如果是32位系统,选择区域优先顺序。

4. 区域水位 (Watermarks)

数据结构如下:

enumzone_watermarks{WMARK_MIN,WMARK_LOW,WMARK_HIGH,NR_WMARK};structzone{/* ... */unsignedlongwatermark[NR_WMARK];// 该区域各种水线/* ... */};

最低水位以下的内存称为紧急保留内存,在内存严重不足的紧急情况下,给承诺“分给我们少量的紧急保留内存使用,我可以释放更多的内存”的进程使用。

Watermark水位控制内核选用了几个重要参数:

  • managed_pages: 伙伴分配器管理的物理页的数量
  • spanned_pages: 当前区域跨越的总页数,包括空洞
  • present_pages: 当前区域可用的所有物理页的数量,包括空洞

它们三者之间的关系:spanned_pages > present_pages > managed_pages

min_free_kbytes的计算:
min_free_kbytes代表的是系统保留空闲内存的最低限度。watermark[WMARK_MIN]的值是通过min_free_kbytes计算出来的。

5. 分区的伙伴分配器核心函数

入口函数:__alloc_pages_nodemask

参数说明:

  • gfp_mask: 分配标志(掩码)
  • order: 阶数
  • zonelist: 首选内存节点的备用区域列表
  • nodemask: 允许从哪些节点分配。如果是NULL,表示允许从所有节点分配。

5.1 快速路径分配页框

函数get_page_from_freelist用于尝试从备用区域列表的区域中分配页框。

它会遍历zonelist,对于每个zone,检查是否满足水位要求(zone_watermark_ok)。如果满足,则尝试从该zone分配。

5.2 慢速路径调用和遇到内存紧缺时的分析

如果在快速路径中分配失败,则会进入慢速路径(__alloc_pages_slowpath)。
慢速路径包含了更复杂的逻辑,例如:

  • 唤醒页回收线程(kswapd)。
  • 忽略水位限制进行分配(如果是紧急分配)。
  • 直接内存回收(Direct Reclaim)。
  • 调用 OOM Killer(如果配置允许)。
  • 重试分配等。
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/22 20:08:30

Java SpringBoot+Vue3+MyBatis 在线文档管理系统系统源码|前后端分离+MySQL数据库

摘要 随着信息技术的快速发展,文档管理已成为企业和个人高效工作的核心需求。传统的文档管理方式依赖本地存储或简单的文件共享工具,存在版本混乱、协作效率低、安全性不足等问题。在线文档管理系统通过云端存储和实时协作功能,能够有效解决这…

作者头像 李华
网站建设 2026/4/23 16:06:25

什么是M-LAG

文章目录为什么需要M-LAG如何实现M-LAG组网M-LAG是如何工作的如何应用M-LAG技术M-LAG(Multichassis Link Aggregation Group)提供一种跨设备链路聚合的技术。M-LAG通过将两台接入交换机以同一个状态和用户侧设备或服务器进行跨设备的链路聚合&#xff0c…

作者头像 李华
网站建设 2026/4/23 14:44:49

线性规划优化:单纯形法

原文:towardsdatascience.com/linear-programming-optimization-the-simplex-method-b2f912e4c6fd 到目前为止,本系列已经涵盖了线性规划的基础知识。在本文中,我们将从基本概念转向底层的细节!本文将介绍单纯形法,这是…

作者头像 李华
网站建设 2026/4/23 11:33:50

springboot集成Jasypt实现配置文件启动时自动解密-ENC

SpringBoot本身并没有自动加解密的功能&#xff0c;平时项目启动时&#xff0c;自动解密配置文件里ENC( )包含的数据&#xff0c;原因是使用了Jasypt&#xff08;Java Simplified Encryption&#xff09;。一、前置条件&#xff0c;maven引入依赖<!-- Spring Boot集成Jasypt…

作者头像 李华
网站建设 2026/4/23 8:46:52

SpringBoot+Vue 甘肃非物质文化网站平台完整项目源码+SQL脚本+接口文档【Java Web毕设】

摘要 甘肃非物质文化遗产作为中华优秀传统文化的重要组成部分&#xff0c;承载着丰富的历史文化信息和民族智慧。随着信息技术的快速发展&#xff0c;传统的非遗保护方式已难以满足现代社会的需求&#xff0c;数字化保护与传承成为重要趋势。本项目旨在构建一个基于SpringBoot和…

作者头像 李华