MPICH > MPID_Init(177).....................: channel initialization failed > /etc/hosts記載ミス


動作環境
CentOS 6.8

Open MPIとMPICHを試した。

code

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

int main(int argc, char** argv) {
    // Initialize the MPI environment
    MPI_Init(NULL, NULL);

    // Get the number of processes
    int world_size;
    MPI_Comm_size(MPI_COMM_WORLD, &world_size);

    // Get the rank of the process
    int world_rank;
    MPI_Comm_rank(MPI_COMM_WORLD, &world_rank);

    // Get the name of the processor
    char processor_name[MPI_MAX_PROCESSOR_NAME];
    int name_len;
    MPI_Get_processor_name(processor_name, &name_len);

    // Print off a hello world message
    printf("Hello world from processor %s, rank %d"
           " out of %d processors\n",
           processor_name, world_rank, world_size);

    // Finalize the MPI environment.
    MPI_Finalize();
}

実行

上記のコードについてmpiccでコンパイルしてmpirun -np 6 ./a.outを実行した。

Open MPIの方では特にエラーにならなかった。

MPICHでは以下のようなエラーが出た。

Fatal error in PMPI_Init_thread: Other MPI error, error stack:
MPIR_Init_thread(467)..............: 
MPID_Init(177).....................: channel initialization failed
MPIDI_CH3_Init(70).................: 
...

http://stackoverflow.com/questions/23112515/mpich2-gethostbyname-failed
によるとホスト名の解決がされてなかった。

/etc/hostsを編集してからはOpen MPIと同じように正常終了した。