百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

不了解NUMA,就看不懂Linux内核

liuian 2025-05-14 14:54 37 浏览

哈喽,我是子牙,一个很卷的硬核男人


深入研究计算机底层、Windows内核、Linux内核、Hotspot源码……聚焦做那些大家想学没地方学的课程。为了保证课程质量及教学效果,一年磨一剑,三年先后做了这些课程:手写JVM、手写OS、带你用纯汇编写OS、手写64位多核OS、实战Linux内核…


最近在备课《实战Linux内核》内存专题,把NUMA好好研究了一下,写成文章,Mark一下,顺便分享给有缘人


NUMA是什么呢?一种内存访问架构,与它相对应的是SMP架构,它俩之间有什么区别呢?既然有了SMP架构,又为什么会出现NUMA架构呢?等下解释


回到这篇文章的主题,为什么我说不深入理解NUMA,就看不懂Linux内核?因为Linux内核的内存模块是基于NUMA架构设计的,而几乎所有的内核模块,都是基于内存模块起家的。你可能要问:那SMP架构怎么办?等下会讲到


关于NUMA,我研究了哪些呢:

  1. Linux内核是如何取到所有的NUMA节点的信息的?为此我还在我之前写的64位多核操作系统上把代码写出来了,才得以真正理解,等下展示给大家看。所以我说,你只有有能力写一个Linux内核,你才有能力自己去研究Linux内核,才能真正玩明白,否则只能听别人告诉你!
  2. CPU个数、CPU核、CPU线程与NUMA节点之间的关系
  3. Linux内核在当前NUMA节点内存不足的时候,会去相邻节点分配内存,相邻节点的定义标准是什么?
  4. 每个NUMA节点都是从地址0开始的吗?还是跟SMP架构是一样的,每个NUMA节点占一段内存,那每个NUMA节点占多少内存呢?是平均分配吗?还是可以配置?那如何配置呢?
  5. Linux内核中的ZONE_DMA、ZONE_DMA32、ZONE_NORMAL、ZONE_HIGHMEM与NUMA节点又是怎样的关系?
  6. Linux内核中的内存空洞(unused hole)到底是什么?


以下,enjoy


NUMA vs SMP

先来点铺垫知识,让我们在此处达成共识


我们平时接触的设备都是SMP架构,只有一个内存节点,所有CPU通过总线访问内存

那NUMA架构呢?每个CPU有其直接访问的内存,当前CPU能直接访问的内存不够时,还可以去兄弟节点分配内存,这就是Linux内核中讲的去相邻节点分配内存

这个有点像Java虚拟机hotspot中的TLAB,线程私有内存(堆),解决高并发。NUMA实现的是CPU私有内存。毕竟一个是虚拟机,一个是硬件本身,解决问题的维度就不同。所以你看,思想是相通的


那什么样的设备用NUMA架构呢

有了SMP架构,为什么还要NUMA架构,因为SMP架构下,所有的核都要通过总线去访问内存,为了支持高并发,我们一般都要用到CPU提供的原子指令,原子指令的底层一般是通过锁总线或者CPU缓存实现的。


我们就拿锁总线来理解,比如CPU0要原子访问内存,其他CPU核就无法访问内存,可以想象在高并发场景下,这样的硬件性能如何。只要有一个核要访问内存,其他核都要等待,直到那个核释放总线


总结一下:SMP架构简单,但是在CPU核特别多的场景下,原子访问内存的开销很大,所以衍生了NUMA架构。一般新的技术是为了解决旧技术存在的问题,同时带来的是更高的复杂性。


Linux2.6内核被看成是Linux内核发展的里程碑,因为这个版本引入了很多新特性,NUMA也是这个版本引入的。你对比看下2.6前后的内核源码,你会发现2.6以后的内存模块的代码,对比之前的,要复杂很多很多。接下来我们就来讲讲,Linux内核是如何支持NUMA的


NUMA在Linux中的存在形式

来张可以说明一切的图

在Linux内核中,每个NUMA节点用结构体pglist_data来描述。那SMP架构呢?Linux内核会当成只要一个NUMA节点来处理

图中的ZONE_DMA、ZONE_DMA32、ZONE_NORMAL又是什么?这就要说到64位Linux内核要兼容硬件、32位等各种兼容问题,所以将内存拆成了一个一个的zone,理解这个对Linux内核非常非常重要

什么是DMA,你可以理解成主板提供的一种机制,能够在CPU不参与的情况下读写数据,大大节省了CPU的性能。有些主板提供的DMA只能访问低16M内存,所以有ZONE_DMA,有些32位主板提供的DMA能够访问4G以内的内存,所以有ZONE_DMA32。


32位CPU开启PAE的情况下,能够访问的物理内存超过4G,29912分页下,最多可访问的物理内存是64G,因此设立了ZONE_HIGHMEM。这个区域只在32位Linux内核中存在,4G-64G内存在这个ZONE中。16M-4G之间的内存,就是ZONE_NORMAL区域


看下64位Linux内核中存在的Zone


再看下32位Linux内核中存在的Zone。你觉得为什么没有ZONE_DMA32呢?留言区告诉我你的答案


最后看下Linux内核中,我的启动参数如下

我设置的机器有4个CPU,两个NUMA节点,每个NUMA节点的内存容量是2.5G


看下NUMA节点0的ZONE_DMA,看zone_start_pfn、spanned_pages,内存范围是从1-0xffffff,图中显示的是页数,要乘以4096才是真实的内存大小

按理说这个访问应该是0-0xffffff,为什么是从1开始的,我问了下chatgpt


看下NUMA节点0的ZONE_DMA32,你是不是想问这些数据是怎么来的,等下就会讲到


NUMA节点1的ZONE_DMA,是空的。言外之意就是在NUMA架构中,每个CPU访问的内存不是从0开始的,是在前面的NUMA节点中的内存累加过来的

NUMA节点1的ZONE_DMA32

NUMA节点1的ZONE_NORMAL


我本来试图找一篇类似的文章也像我这样把这些东西讲清楚,真是找遍了都找不到,才发现,大家对Linux内核的理解,绝大多数都只是纸上谈兵而已!


数据怎么来的

我们自实现操作系统,或者是Linux内核、Windows内核,都需要获取到内存条的信息,那谁有这些信息呢?主板


主板提供了e820功能让操作系统内核可以获取到内存信息,其中flag=2的区域就是所谓的内存空洞


在NUMA架构下,e820功能返回的数据过于简单了,无法支持Linux内核支持NUMA架构,就需要通过ACPI获取到最正宗的NUMA信息


对比前面贴的Linux内核中各个ZONE的数据,是不是几乎一样呢?


这篇文章,应该是你看过的把Linux内核与NUMA讲的最透彻的文章吧!创作不易,能不能麻烦各位帮忙分享一下


如果你也想像我一样,能够自由使用各种技术、自由研究各种问题而不用等着别人告诉你答案……你得有能力写一个操作系统内核。

相关推荐

MySQL慢查询优化:从explain到索引,DBA手把手教你提升10倍性能

数据库性能是应用系统的生命线,而慢查询就像隐藏在系统中的定时炸弹。某电商平台曾因一条未优化的SQL导致订单系统响应时间从200ms飙升至8秒,最终引发用户投诉和订单流失。今天我们就来系统学习MySQL...

一文读懂SQL五大操作类别(DDL/DML/DQL/DCL/TCL)的基础语法

在SQL中,DDL、DML、DQL、DCL、TCL是按操作类型划分的五大核心语言类别,缩写及简介如下:DDL(DataDefinitionLanguage,数据定义语言):用于定义和管理数据库结构...

闲来无事,学学Mysql增、删,改,查

Mysql增、删,改,查1“增”——添加数据1.1为表中所有字段添加数据1.1.1INSERT语句中指定所有字段名语法:INSERTINTO表名(字段名1,字段名2,…)VALUES(值1...

数据库:MySQL 高性能优化规范建议

数据库命令规范所有数据库对象名称必须使用小写字母并用下划线分割所有数据库对象名称禁止使用MySQL保留关键字(如果表名中包含关键字查询时,需要将其用单引号括起来)数据库对象的命名要能做到见名识意,...

下载工具合集_下载工具手机版

迅雷,在国内的下载地位还是很难撼动的,所需要用到的地方还挺多。缺点就是不开会员,软件会限速。EagleGet,全能下载管理器,支持HTTP(S)FTPMMSRTSP协议,也可以使用浏览器扩展检测...

mediamtx v1.15.2 更新详解:功能优化与问题修复

mediamtxv1.15.2已于2025年10月14日发布,本次更新在功能、性能优化以及问题修复方面带来了多项改进,同时也更新了部分依赖库并提升了安全性。以下为本次更新的详细内容:...

声学成像仪:泄露监测 “雷达” 方案开启精准防控

声学成像仪背景将声像图与阵列上配装的摄像实所拍的视频图像以透明的方式叠合在一起,就形成了可直观分析被测物产生状态。这种利用声学、电子学和信息处理等技术,变换成人眼可见的图像的技术可以帮助人们直观地认识...

最稳存储方案:两种方法将摄像头接入威联通Qu405,录像不再丢失

今年我家至少被4位邻居敲门,就是为了查监控!!!原因是小区内部监控很早就停止维护了,半夜老有小黄毛掰车门偷东西,还有闲的没事划车的,车主损失不小,我家很早就配备监控了,人来亮灯有一定威慑力,不过监控设...

离岗检测算法_离岗检查内容

一、研发背景如今社会许多岗位是严禁随意脱离岗位的,如塔台、保安室、监狱狱警监控室等等,因为此类行为可能会引起重大事故,而此类岗位监督管理又有一定困难,因此促生了智能视频识别系统的出现。二、产品概述及工...

消防安全通道占用检测报警系统_消防安全通道占用检测报警系统的作用

一、产品概述科缔欧消防安全通道占用检测报警系统,是创新行业智能监督管理方式、完善监管部门动态监控及预警预报体系的信息化手段,是实现平台远程监控由“人为监控”向“智能监控”转变的必要手段。产品致力于设...

外出住酒店、民宿如何使用手机检测隐藏的监控摄像头

最近,一个家庭在他们的民宿收到了一个大惊喜:客厅里有一个伪装成烟雾探测器的隐藏摄像头,监视着他们的一举一动。隐藏摄像头的存在如果您住在酒店或民宿,隐藏摄像头不应再是您的担忧。对于民宿,房东应报告所有可...

基于Tilera众核平台的流媒体流量发生系统的设计

曾帅,高宗彬,赵国锋(重庆邮电大学通信与信息工程学院,重庆400065)摘要:设计了一种基于Tilera众核平台高强度的流媒体流量发生系统架构,其主要包括:系统界面管理模块、服务承载模块和流媒体...

使用ffmpeg将rtsp流转流实现h5端播放

1.主要实现rtsp转tcp协议视频流播放ffmpeg下载安装(公认业界视频处理大佬)a、官网地址:www.ffmpeg.org/b、gitHub:github.com/FFmpeg/FFmp…c、推...

将摄像头视频流从Rtsp协议转为websocket协议

写在前面很多通过摄像头拿到的视频流格式都是Rtsp协议的,比如:海康威视摄像头。在现代的浏览器中,已经不支持直接播放Rtsp视频流,而且,海康威视提供的本身的webSdk3.3.0视频插件有很多...

华芸科技推出安全监控中心2.1 Beta测试版

全球独家支持hdmi在线实时监看摄像机画面,具单一、循环或同时监看四频道视频影像,可透过华芸专用红外线遥控器、airemote或是键盘鼠标进行操作,提供摄像机频道增购服务,满足用户弹性扩增频道需...