私はMPIを使用してプログラムを作成し、2つの異なるクラスターにアクセスします。私はシステム管理が良くないので、そこで使われているソフトウェア、OS、コンパイラについては何も教えてくれません。MPIはRecvデッドロックを送信します
#include "mpi.h"
#include <iostream>
int main(int argc, char **argv) {
int rank, numprocs;
MPI_Status status;
MPI_Init(&argc, &argv);
MPI_Comm_rank(MPI_COMM_WORLD, &rank);
MPI_Comm_size(MPI_COMM_WORLD, &numprocs);
int x = rank;
if (rank == 0) {
for (int i=0; i<numprocs; ++i)
MPI_Send(&x, 1, MPI_INT, i, 100500, MPI_COMM_WORLD);
}
MPI_Recv(&x, 1, MPI_INT, 0, 100500, MPI_COMM_WORLD, &status);
MPI_Finalize();
return 0;
}
エラーメッセージが関連している:
Fatal error in MPI_Send: Other MPI error, error stack:
MPI_Send(184): MPI_Send(buf=0x7fffffffceb0, count=1, MPI_INT, dest=0, tag=100500, MPI_COMM_WORLD) failed
MPID_Send(54): DEADLOCK: attempting to send a message to the local process without a prior matching receive
なぜようである。しかし、一台のマシン上で、私はそのようなコードを使用して、デッドロックがありますか?私は理解できません、なぜそれは1つのマシンで起こりますが、別のマシンでは起こりませんか?
ありがとう、私の場合、私はMPI_Bcastを使用できません(コード関連は私のreallifeプログラムの一例です)。 – user2923317
MPIには多くの異なる一括操作が用意されています。適用可能な場合はいつでもそれらを使用することが一般に好ましい。アプリケーションの通信パターンに近い例を示すことをお勧めします。 – Zulan