打开 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 在简单程序中退出并出现错误的主要内容,如果未能解决你的问题,请参考以下文章