哪个进程进入 MPI 中的哪个 cpu 套接字?

Posted

技术标签:

【中文标题】哪个进程进入 MPI 中的哪个 cpu 套接字?【英文标题】:Which process goes to which cpu socket in MPI? 【发布时间】:2022-01-11 22:36:41 【问题描述】:

我正在运行一个 MPI 程序,并且在我的主机文件中我只有一个节点。 该节点有 2 个 scoket,每个 8 个物理内核,并且超线程被禁用。

mpiexec -n 8 -f /pathtohostfile/host_file_test ./a.out

我正在使用 likwid 来测量我的程序消耗的能量。

问题:

    以上 8 个进程是否在同一个套接字上运行(以节省能源)或进程可以随机分配到任一套接字? 不确定,但是进程上下文可以切换到另一个套接字吗? 如果进程是随机分配的,我可以将我的进程固定到核心/插座上以测量能量吗?

【问题讨论】:

【参考方案1】:

由于您只有一个节点,您的 8 个进程都在 Linux 调度程序的控制之下,因此,除非您使用 numactl 或其他东西来固定它们,否则操作系统将放置它们以实现最佳负载平衡。它可能会决定迁移它们。查看numactl 和其他“固定”工具。 hwloc 也可以为你做。

【讨论】:

以上是关于哪个进程进入 MPI 中的哪个 cpu 套接字?的主要内容,如果未能解决你的问题,请参考以下文章

分析占用了大量 CPU 处理时间的是Java 进程中哪个线程

分析占用了大量 CPU 处理时间的是Java 进程中哪个线程

如何找到哪个进程绑定了一个套接字但不监听?

查看JAVA进程中哪个线程CPU消耗最高

使用MPI_Sendrecv实现MPI_Allgather

MPI Alltoallv 还是更好的个人发送和接收? (表现)