2012-04-11 104 views
6

如何确认主机是否支持NUMA? Oracle doc表示,NUMA感知从2.6.19开始,但NUMA man page说它是在2.6.14中引入的。我想确保以-XX:+UseNUMA开始的Java进程实际上正在利用某些东西。如何确认NUMA?

检查的numa_maps,我知道我让他们:

# find /proc -name numa_maps 
/proc/1/task/1/numa_maps 
/proc/1/numa_maps 
/proc/2/task/2/numa_maps 
/proc/2/numa_maps 
/proc/3/task/3/numa_maps 

虽然我的内核是什么背后甲骨文指出:

# uname -sr 
Linux 2.6.18-92.el5 

我目前使用的64位jdk1.6.0在RHEL5.1上_29。

+0

您是否考虑将内核升级到更新的内核? – 2012-04-11 16:17:35

+0

RHEL 5.1(2007-11-07)已经很老了,可能是它的升级时间。 – 2012-04-11 16:23:58

+0

@Peter根据我的经验,使用NUMA处理器的人通常不是负责更新软件的人,必须经历相当多的官僚主义才能更新它。刚刚看到一个* python 2.4 *安装在一台超级计算机上有2k内核.. – Voo 2012-04-11 16:34:46

回答

8

这些/ proc文件的存在表明你的linux内核是numa-aware的。不要过多关注版本号的比较,特别是在Oracle/RHEL内核中,供应商端口/回送许多功能,而不会将版本字符串保持为“最新”。

$ grep NUMA=y /boot/config-`uname -r` 
CONFIG_NUMA=y 
CONFIG_K8_NUMA=y 
CONFIG_X86_64_ACPI_NUMA=y 
CONFIG_ACPI_NUMA=y 

$ numactl --hardware 
available: 2 nodes (0-1) 
node 0 size: 18156 MB 
node 0 free: 9053 MB 
node 1 size: 18180 MB 
node 1 free: 6853 MB 
node distances: 
node 0 1 
    0: 10 20 
    1: 20 10 
+0

rhel的支持也是我的想法。使用/ boot/config良好的调用 – 2012-04-11 17:28:40

+2

但这是否意味着JVM使用它?是否有任何记录表明numa正在使用? – easytiger 2013-06-05 10:52:24

1

Oracle的文档还指出:

测试同样的事情的其他方式

注:有在Linux内核中的已知漏洞,可能导致JVM是时崩溃t与-XX:UseNUMA。该错误在2012年得到修复,因此这不应该影响最新版本的Linux内核。要查看你的内核是否有这个bug,你可以运行native reproducer

这是我在这里转载证明它的简单:

http://docs.oracle.com/javase/7/docs/technotes/guides/vm/reproducer.c

要构建再生器中,您可能需要安装numactl的numactl的-devel的包根据您的分布。详情请参阅man numa_maps

#include <numaif.h> 
#include <numa.h> 
#include <stddef.h> 
#include <sys/mman.h> 
#include <stdint.h> 

int main(void) { 
    if (numa_all_nodes_ptr == (void*)0) { 
    return -1; 
    } 

    size_t pagesize = getpagesize(); 

    void* mapped_memory = mmap(NULL, 3 * pagesize, PROT_READ|PROT_WRITE, 
MAP_PRIVATE|MAP_ANONYMOUS, -1, 0); 
    if (mapped_memory == MAP_FAILED) { 
    return -2; 
    } 

    void* page0 = mapped_memory; 
    void* page1 = (void*)((uintptr_t)page0 + pagesize); 
    void* page2 = (void*)((uintptr_t)page1 + pagesize); 

// Set up the last page as interleaved. 
    mbind(page2, pagesize, MPOL_INTERLEAVE, numa_all_nodes_ptr->maskp, 
numa_all_nodes_ptr->size, 0); 

    // Setup the last two pages as interleaved. 
    mbind(page1, 2 * pagesize, MPOL_INTERLEAVE, 
numa_all_nodes_ptr->maskp, numa_all_nodes_ptr->size, 0); 

    *((char*)page2) = 2; 
    *((char*)page1) = 1; 
    *((char*)page0) = 0; // Crash here, when mbind_merge was broken. 

    return 0; 
} 

所以,我把不确定性意味着2.6.19是第安全版本。

+0

你如何编译这个? numa标题在哪里? – sloven 2015-02-05 18:27:40

+0

@Nik您可能需要根据man numa_maps'Library support'安装numactl或numactl-devel, – 2015-02-06 22:42:01