【问题标题】:Open MPI - mpirun exits with error on simple program打开 MPI - mpirun 在简单程序中退出并出现错误
【发布时间】: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 似乎是同样的错误。下面./ 的答案应该有效。

标签: c mpi openmpi


【解决方案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' 
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 2014-01-30
      • 1970-01-01
      • 2012-08-14
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2015-05-24
      相关资源
      最近更新 更多