Numa初识

本文分享自天翼云开发者社区《Numa初识》,作者:j****n

Numa产生

在二十世纪九十年代被开发出来的。

首次商业化实现基于NUMA的Unix系统的是对称多处理XPS-100系列服务器。

由VAST公司的Dan Gielen为HISI设计的。

这个架构的巨大成功使HISI成为了欧洲的顶级Unix厂商。

Numa简介

NUMA(Non-Uniform Memory Access):非一致存储访问结构。

基本特征是具有多个 CPU 模块,每个 CPU 模块由多个 CPU( 如 4 个 ) 组成,并且具有独立的本地内存、 I/O 槽口等。由于其节点node之间可以通过互联模块 ( 如称为 Crossbar Switch) 进行连接和信息交互,因此每个 CPU 可以访问整个系统的内存 。

访问本地内存的速度将远远高于访问远地内存 ( 系统内其它节点的内存 ) 的速度。

Numa结构

node包括一个或者多个Socket,以及与之相连的local memory;

socket就是主板上的CPU插槽;

core就是socket里独立的一组程序执行的硬件单元,比如寄存器,计算单元等;

thread:就是超线程hyperthread的概念,逻辑的执行单元,独立的执行上下文,但是共享core内的寄存器和计算单元

Numa相关命令

lscpu:查看机器的NUMA拓扑结构

上图中机器有2个sockets,每个sockets包含1个numa node,每个numa node中有8个cores,每个cores包含2个thread,所以总的threads数量=2(sockets)×1(node)×8(cores)×2(threads)=32.

numastat:查看numa状态

numa_hit是打算在该节点上分配内存,最后从此节点分配的次数;

num_miss是打算在该节点分配内存,最后从其他节点分配的次数;

num_foregin是打算在其他节点分配内存,最后从此节点分配的次数;

interleave_hit是采用interleave策略最后从该节点分配的次数;

local_node该节点上的进程在该节点上分配的次数 other_node是其他节点进程在该节点上分配的次数

相关推荐
每一步都算数13 小时前
从通用对话到专属智库:两种AI部署模式,让企业数据真正“活“起来
架构
尘世中一位迷途小书童13 小时前
项目大扫除神器:Knip —— 将你的代码库“瘦身”到底
前端·架构·代码规范
狗哥哥14 小时前
企业级 Vue 3 项目图标系统重构实践:从多源混乱到单一数据源
前端·vue.js·架构
管理大亨14 小时前
Elasticsearch + Logstash + Filebeat + Kibana + Redis架构
redis·elasticsearch·架构
神算大模型APi--天枢64614 小时前
从异构调度到边缘部署:国产大模型算力平台的后端开发能力拆解
大数据·人工智能·科技·架构·硬件架构
橙序员小站14 小时前
Springboot3.0并不能拯救你的屎山
java·后端·架构
Hello.Reader15 小时前
理解 Aerospike 架构从 Client 到 Data Layer 的解析
架构
snow@li15 小时前
前端:软件开发中的秤砣理论 / 越简单越可靠 / 提炼组织架构 / 精确标定工作 / 有主干有支流 / 不追求繁琐 / 不做表面工作
前端·架构
阿拉斯攀登15 小时前
STM32 架构概述
stm32·单片机·架构
前端不太难15 小时前
RN 的导航体系太混乱,如何选型和架构设计?
前端·react native·架构