打开 MPI - mpirun 在简单程序中退出并出现错误

Posted

技术标签:

【中文标题】打开 MPI - mpirun 在简单程序中退出并出现错误【英文标题】:Open MPI - mpirun exits with error on simple program 【发布时间】:2015-09-28 14:20:14 【问题描述】:

我最近在我的计算机上安装了 OpenMPI,当我尝试运行一个简单的 Hello World 程序时,它退出并出现下一个错误:

-------------------------------------------------------
Primary job  terminated normally, but 1 process returned
a non-zero exit code.. Per user-direction, the job has been aborted.
-------------------------------------------------------

这是程序的源代码:

#include <mpi.h>
#include <stdio.h>

int main(int argc, char *argv[])

    int size, rank;

    MPI_Init(&argc, &argv);
    MPI_Comm_size(MPI_COMM_WORLD, &size);
    MPI_Comm_rank(MPI_COMM_WORLD, &rank);

    printf("Hello\n");

    MPI_Finalize();

    return 0;

这是我编译程序的方式:

mpicc -o hello hello.c

我用它来执行它

mpirun -np 2 hello

编译时不会出错,如果我运行./hello,它运行正常。

请原谅我的英语,欢迎任何更正。

【问题讨论】:

确保您使用相同的 MPI 发行版(OpenMPI、MPICH、MVAPICH)和版本来编译 mpicc 并运行程序 mpirun。您的错误很可能是我的版本和/或发行版不匹配造成的。 我已经下载并安装了 OpenMPI 的最后一个稳定版本。在安装之前,我没有安装 MPI 版本 检查返回值。 您提到您使用了最后一个稳定版本,但那是哪个版本? This 似乎是同样的错误。下面./ 的答案应该有效。 【参考方案1】:

你必须 ./ 可执行文件名 试试这个,mpirun -np 2 ./hello

【讨论】:

【参考方案2】:

试试:

mpirun -x LD_PRELOAD=libmpi.so -np 2 hello

如果它有效,则您的 OpenMPI 安装可能存在问题。一个简单的解决方法是定义一个别名。如果你使用 bash,添加 ~/.bashrc:

alias mpirun='mpirun -x LD_PRELOAD=libmpi.so' 

【讨论】:

以上是关于打开 MPI - mpirun 在简单程序中退出并出现错误的主要内容,如果未能解决你的问题,请参考以下文章

结束 mpirun 进程会终止 bash 循环

在Jupyter笔记本中使用`mpirun`

使用和不使用 mpirun 运行程序的区别

如何在 Centos 7 中使用 firewalld 启用 MPI mpirun

从所有MPI流程的标准输入读取

错误:libtool - 编译 MPI 程序时