如何查看NUMA当前状态?

在Linux系统中,NUMA(Non-Uniform Memory Access,非统一内存访问)是提升多处理器服务器性能的关键技术,它通过将CPU和内存划分为多个”节点”,让每个CPU优先访问本地内存,减少跨节点延迟,以下是详细配置指南:
在配置前,先检查系统NUMA支持情况:

  1. 查看硬件支持
    执行命令:

    lscpu | grep -i numa

    若输出包含NUMA node(s)且数量大于1(如NUMA node(s): 2),说明硬件已支持NUMA。

  2. 检查NUMA是否启用

    dmesg | grep -i numa

    若显示NUMA: Using hardware configuration或类似信息,表示内核已启用NUMA。


开启NUMA的核心步骤

BIOS/UEFI 中启用NUMA(必需)

NUMA是硬件级功能,必须先在BIOS中开启

  • 重启服务器,进入BIOS/UEFI设置(通常按DelF2F12)。
  • Advanced Settings > CPU/Memory Configuration 中找到选项:
    • 名称可能为 NUMA SupportNode InterleavingMemory Interleaving
  • 关闭内存交错(Disable Memory Interleaving)
    此选项开启时内存均匀分布(模拟UMA),需关闭以启用NUMA。
  • 保存设置并重启。

⚠️ 注意:不同厂商(如Dell、HP、联想)路径略有差异,请参考服务器手册。

Linux内核参数调整

若BIOS已启用NUMA但系统未识别,需配置内核:

  • 编辑GRUB配置
     sudo vim /etc/default/grub
  • 修改内核启动参数
    GRUB_CMDLINE_LINUX行添加:

     GRUB_CMDLINE_LINUX="... numa=on"

    某些系统(如VMware虚拟机)需额外添加:

     GRUB_CMDLINE_LINUX="... numa=on transparent_hugepage=never"
  • 更新GRUB并重启
     sudo grub2-mkconfig -o /boot/grub2/grub.cfg  # CentOS/RHEL
     sudo update-grub                             # Ubuntu/Debian
     sudo reboot

验证NUMA状态

重启后确认配置生效:

  1. 检查NUMA节点

    numactl --hardware

    输出示例:

    available: 2 nodes (0-1)  # 表示2个NUMA节点已激活
    node 0 size: 32768 MB
    node 1 size: 32768 MB
  2. 查看内存分配策略

    numastat  # 显示各节点内存使用统计

高级配置工具

numactl:进程级NUMA控制

  • 指定进程运行在节点0,并使用本地内存
     numactl --cpunodebind=0 --membind=0 <command>
  • 示例:运行MySQL在节点0
     numactl --cpunodebind=0 --membind=0 /usr/sbin/mysqld

numad:自动NUMA优化

  • 安装并启用服务
     sudo yum install numad    # CentOS/RHEL
     sudo systemctl start numad

    numad 自动调整进程与内存的绑定,适合动态负载场景。

内核参数调优

  • 禁用区域回收策略(避免内存溢出)
     echo 0 > /proc/sys/vm/zone_reclaim_mode
  • 调整内存分配策略/proc/sys/kernel/numa_balancing):
    • 1:启用自动负载均衡(默认)
    • 0:关闭(需手动绑定)

注意事项

  1. 性能权衡
    • 数据库(如MySQL、Oracle)开启NUMA通常提升性能。
    • 部分应用(如高吞吐网络服务)可能因跨节点访问导致延迟,需测试后决定。
  2. 虚拟机场景
    VMware/KVM需同时开启虚拟NUMA(vNUMA)并匹配Guest OS配置。
  3. 内存不足处理
    若某节点内存耗尽,可通过numactl --interleave=all启用交错分配,但会牺牲性能。

开启NUMA需三步:BIOS启用 → 内核参数确认 → 系统工具优化,正确配置后,多路服务器性能可提升20%~50%,建议结合numastatperf工具监控效果,根据应用负载调整策略。

引用说明

  • 内核参数文档:https://www.kernel.org/doc/html/latest/admin-guide/kernel-parameters.html
  • Red Hat NUMA优化指南:https://access.redhat.com/documentation/en-us/red_hat_enterprise_linux/7/html/performance_tuning_guide/sect-red_hat_enterprise_linux-performance_tuning_guide-numa
  • Ubuntu服务器配置:https://ubuntu.com/server/docs/performance-numa

原创文章,发布者:酷番叔,转转请注明出处:https://cloud.kd.cn/ask/7176.html

(0)
酷番叔酷番叔
上一篇 2025年7月13日 05:19
下一篇 2025年7月13日 05:37

相关推荐

  • Linux系统备份迁移到新硬盘后无法启动,是什么原因导致的呢?

    将Linux系统备份到新硬盘后无法启动,是用户升级或迁移系统时常见的问题,这通常涉及引导配置、分区表、硬盘识别或系统文件路径等多个方面的错误,以下从常见原因入手,逐步分析排查和解决方法,帮助用户快速定位问题并恢复系统,备份后启动失败的常见原因及解决思路分区表格式与引导扇区不匹配Linux系统支持MBR(主引导记……

    2025年9月9日
    15800
  • 如何安全删除Linux系统用户文件的操作步骤与注意事项?

    在Linux系统中删除用户文件是一项需要谨慎操作的任务,因为错误的删除可能导致系统故障或数据丢失,无论是删除特定用户的个人文件,还是彻底移除用户及其所有关联数据,都需要遵循规范的流程,并充分理解操作的影响,本文将详细讲解不同场景下的文件删除方法、注意事项及常用工具,帮助用户安全、高效地完成操作,删除前的准备工作……

    2025年9月15日
    13000
  • hv如何在线迁移Linux系统?在线迁移方法详解?

    在线迁移Linux虚拟机是Hyper-V环境中实现业务连续性的重要操作,通过零停机或短时间停机的方式将运行中的Linux虚拟机从源主机迁移至目标主机,可有效避免服务中断,适用于负载均衡、主机维护等场景,以下是详细的操作流程及注意事项,环境准备与前置要求在线迁移前需确保源主机与目标主机满足基础条件,这是迁移成功的……

    2025年10月7日
    14200
  • Linux系统如何用指令打开火狐浏览器?

    在Linux系统中,通过指令打开火狐浏览器(Firefox)是日常操作和自动化任务中的常见需求,尤其适用于服务器管理、脚本调用或快速启动场景,本文将详细介绍不同Linux发行版下火狐的安装方法、基础启动指令、常用参数配置及高级用法,帮助用户灵活掌握指令操作火狐的技巧,火狐浏览器的安装(前提条件)在通过指令打开火……

    2025年8月28日
    1.6K00
  • Linux字符界面如何进行粘贴复制?

    在Linux字符界面(终端)中,复制粘贴操作因场景(本地终端、远程SSH、纯字符界面等)和工具差异而有所不同,掌握多种方法能显著提升工作效率,本文将详细讲解不同场景下的复制粘贴技巧,涵盖终端模拟器快捷键、命令行工具、多路复用工具及纯字符界面解决方案,终端模拟器中的鼠标复制粘贴(本地图形界面终端)在本地Linux……

    2025年8月27日
    16800

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信