1.并行编程模式-消息传递:

具有通用功能的消息传递库有PICL、PVM、PARMACS、P4、MPI等;面向特定系统定制的消息传递库有MPL、NX、CMMD等。

消息传递模型的主要缺点是:要求在编程过程中参与显式的数据划分和进程间同步,因此会需在解决数据依赖、预防死锁上话费较大精力。

2.MPI消息传递通信的基本概念

  • 缓存区

MPI环境定义了3种缓存区:

应用缓冲区

指保存将要发送或接受的数据的地址空间,既消息格式定义的内容部分。

系统缓冲区

MPI环境为通信所准备的存储空间。

用户向系统注册的缓冲区

指用户使用某些API(MPI_Bsend)时,在程序中显式申请的存储空间,然后注册到MPI环境中供通信使用。

  • 通信子(communicator)

通信子是MPI环境管理进程及通信的基本设施。(eg:MPI_COMM_WORLD)。对某个进程的操作必须放在通信子内方可有效。

  • 通信协议:

MPI环境采用以下通信协议:

立即通信协议(Eager)

总是假定目标进程具备保存消息数据的能力。注:该方式减少了同步延迟,简化编程,但需要相当数量的缓冲区。

集中通信协议(Rendezvous)

在目标准备好后,才可执行发送动作。注:该方式可确保可靠和安全,并提供消除多次数据的可能,但增加了编程复杂性(需结合wait/test等机制),同时也带来了同步延迟(等待进程许可需要时间)。

断消息协议(Short)

消息数据与信封封装在一起发送。

From:《MPI并行程序设计实例教程》