我使用Windows 7操作系统将MPICH2安装到两台计算机('suaddell'和'o01')。我使用VC ++ Express Edition 2008进行编译。一切都是好的。我可以在两台主机上运行简单的“Hello World”MPI应用程序。但是当我尝试运行简单的MPI_Send和MPI_Recv应用程序时,程序不会结束,它会挂起。通过使用资源监视器,我可以看到它在我的计算机和远程主机上无限运行。如果我按“Ctrl + C”,它会结束并显示在下面的消息中,它假装每件事情都正常。
C:\>mpiexec.exe -hosts 2 suaddell o01 -noprompt mesajlasma.exe
mpiexec aborting job...
Received Message :Hello World
_OK!_
job aborted:
rank: node: exit code[: error message]
0: suaddell: 123: mpiexec aborting job
1: o01: 123
#include "stdafx.h"
#include "string.h"
#include "mpi.h"
int main(int argc, char* argv[])
{
int nTasks, rank;
char mesaj[20];
MPI_Status status;
MPI_Init(&argc,&argv);
MPI_Comm_size(MPI_COMM_WORLD,&nTasks);
MPI_Comm_rank(MPI_COMM_WORLD,&rank);
if(rank == 1)
{
strcpy_s(mesaj, "Hello World");
if (MPI_SUCCESS==MPI_Send(mesaj, strlen(mesaj)+1, MPI_CHAR, 0, 7, MPI_COMM_WORLD)) printf("_OK!_\n");
}
if(rank == 0)
{
MPI_Recv(mesaj, 20, MPI_CHAR, 1, 7, MPI_COMM_WORLD, &status);
printf("Received Message :%s\n", mesaj);
}
MPI_Finalize();
return 0;
}
。 (这里有很多行) 的
......command written to left: "cmd=result src=0 dest=2 tag=5 cmd_tag=0 ctx_key=
0 result=SUCCESS "
......\smpd_free_command
.......\smpd_init_command
......./smpd_init_command
....../smpd_free_command
...../smpd_state_writing_cmd
..../smpd_handle_op_write
....sock_waiting for the next event.
....\SMPDU_Sock_wait
(这是我按“Ctrl + C”的最后一行)
如何解决此问题。
提前致谢
答案 0 :(得分:2)
升级到最新版本的MPICH2,版本1.4.1p1。