当前位置: 首页 > news >正文

linux kernel物理内存概述(七)

目录

一、内核中小内存、频繁分配和释放场景

二、slab是内存池化技术

三、内核中使用slab对象池的地方

四、slab内核设计


 

        使用比页小的内存,内核的处理方式使用slab

一、内核中小内存、频繁分配和释放场景

  1. slab首先会向伙伴系统一次性申请一个或者多个物理内存页面,正是这些物理内存页组成了slab内存池。
  2. slab内存池会将这些连续的物理内存页面划分成多个大小相同的小内存块,同一种slab内存池下,划分出来的内存块尺寸是一样的。
  3. 比如内核经常使用的核心数据结构

        task_struct mm_struct ,struct page ,struct file socket对象等。

二、slab是内存池化技术

  1. 当内核需要频繁分配和释放内核对象时,就可以直接从相应的slab对象池中申请和释放内核对象,避免了链路较长的内存分配与释放技术,极大的提升性能。
  2. 利用CPU高速缓存 提高访问速度。当一个对象被直接释放回slab时,这个内核对象还是热的,仍然驻留在CPU高速缓存中。如果这时,继续向SLAB对象池申请对象,SLAB对象池就会把这个刚刚释放,驻留在高速缓存中的对象分配给内核使用,访问起来速度会更快。
  3. 伙伴系统只能分配2^ORDER物理内存页,这会引起占用高速缓存以及TLB的空间较大,导致一些不重要的数据驻留在CPU高速缓存行中占用宝贵的缓存空间,而重要的数据被置换中内存中,slab对象池针对小内存分配场景。可以有效的避免这一点。
  4. 调用伙伴系统的操作会对CPU高速缓存L1CACHE中的Instruction Cache和 Data Cache有污染,因为伙伴系统的长链路调用,相关的一些指令和数据必然会填充到Instruction Cache 和 Data Cache 中,从而将频繁使用的一些指令和数据挤压出去,造成缓存污染。
  5. 使用slab对象池可以充分利用CPU高速缓存,避免多个对象同一cache line的征用。


三、内核中使用slab对象池的地方

 

  • fork 内核需要使用task_struct专属的slab对象池分配task_struct对象

tsk = alloc_task_struct_node(node)
  • 为进程创建虚拟内存空间是,内核使用mm_struct专属的slab对象池分配mm_struct对象。

struct mm_struct * mm = allocate_mm()
  • 向高速缓存page cache查找对应的文件缓存页时,内核需要使用struct page专属的slab对象池分配

 struct page *page = __page_cache_alloc(gfp_mask)
  • 使用open打开文件时,内核需要使用struct file 专属的slab对象池分配 struct file对象

 struct file *flip = alloc_empty_file()
  • socket对象

newsock = sock_alloc();

四、slab内核设计

  • slab对象池可根据情况向伙伴系统一次性申请一页或多个内存页。 
  • 对象的object size可以是任意的,并不是内存对齐的,CPU访问没有对齐的内存比访问对齐的内存速度要慢一倍。不能简单按照尺寸object size来划分内存块,需要考虑对象内存地址要按照 word size进行对齐。
  • 内核为了应对内存读写越界场景,在内存周围插入了一段不可访问的内存区域,这些内存区域使用特定字节0xbb填充,当进程访问到内存是0xbb时,表示已经越界访问了,这段内存区域在slab术语为 red zone。可以理解为红色警戒区。
     

学习参考

https://xxetb.xetslk.com/s/9SQuY

 


 

http://www.lryc.cn/news/316727.html

相关文章:

  • 【C#】.net core 6.0 使用第三方日志插件Log4net,日志输出到控制台或者文本文档
  • TSINGSEE青犀煤矿矿井视频监控与汇聚融合管理视频监管平台建设方案
  • C语言 - 各种自定义数据类型
  • 第四弹:Flutter图形渲染性能
  • 基础算法(三)#蓝桥杯
  • 人工智能在增强数据安全方面的作用
  • python】jupyter notebook导出pdf和pdf不显示中文问题
  • 通过SDKMAN安装各种版本JDK
  • 软考高级:软件架构风格概念和例题
  • Vue3响应式编程
  • 决策树算法优化(一篇文章 理解)
  • 【C语言步行梯】自定义函数、函数递归详谈
  • 小米汽车上市进入倒计时,已开启内部试驾
  • React render方法的原理?在什么时候会被触发?
  • 打卡学习kubernetes——了解kubernetes组成及架构
  • python(ogr)处理geojson为本地shp文件
  • Docker容器化技术(使用Dockerfile制作镜像)
  • C++ struct 结构体类型
  • 什么是VR虚拟现实体验店|VR主题馆加盟|元宇宙文化旅游
  • 【智能家居入门1之环境信息监测】(STM32、ONENET云平台、微信小程序、HTTP协议)
  • AIGC安全研究简述(附资料下载)
  • 初识Spring MVC
  • 云原生之容器编排实践-ruoyi-cloud项目部署到K8S:Nginx1.25.3
  • PHP立体安全攻击向量:保护应用程序的关键挑战
  • 【功能大全】手机短信验证码一键注册登录流程
  • 【Python】【Matplotlib】深入解析plt.grid()---原理、应用与注意事项
  • 数据库规范化设计案例解析
  • 服务器段的连接端口和监听端口编程实现
  • 用“定时执行专家”武装你的电脑,做时间管理大师!
  • css3实现3D立方体旋转特效源码