MPI_Send和MPI_Recv

时间:2011-09-06 12:08:24

标签: parallel-processing mpi mpich

我使用Windows 7操作系统将MPICH2安装到两台计算机('suaddell'和'o01')。我使用VC ++ Express Edition 2008进行编译。一切都是好的。我可以在两台主机上运行简单的“Hello World”MPI应用程序。但是当我尝试运行简单的MPI_Send和MPI_Recv应用程序时,程序不会结束,它会挂起。通过使用资源监视器,我可以看到它在我的计算机和远程主机上无限运行。如果我按“Ctrl + C”,它会结束并显示在下面的消息中,它假装每件事情都正常。


mpiexec命令和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;
}

当程序使用“-verbose”运行时,我可以看到系统在这里等待,直到按“Ctrl + C”:

。 (这里有很多行)

......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”的最后一行)

如何解决此问题。

提前致谢

1 个答案:

答案 0 :(得分:2)

升级到最新版本的MPICH2,版本1.4.1p1。