0

0

c++ MPI怎么用 c++分布式计算编程入门【HPC】

尼克

尼克

发布时间:2025-12-21 17:24:08

|

829人浏览过

|

来源于php中文网

原创

C++ MPI分布式计算核心是各进程运行同一代码,用MPI_Comm_rank区分身份,通过点对点或集体通信交换数据;需先装OpenMPI/MPICH,写含MPI_Init的hello.cpp,编译后mpirun启动多进程;强调无主从、重集体通信、避死锁、跨节点只需hostfile。

c++ mpi怎么用 c++分布式计算编程入门【hpc】

用 C++ 做 MPI 分布式计算,核心就一条:每个进程运行同一份代码,靠 MPI_Comm_rank 区分身份,用 MPI_Send/MPI_Recv 或集体通信(如 MPI_BcastMPI_Reduce)交换数据。不写线程同步,不手动管网络,MPI 库帮你调度到多台机器或多个 CPU 核上。

第一步:装环境 & 写最简“Hello World”

确保系统有 MPI 实现(推荐 OpenMPI 或 MPICH)。Ubuntu 上可:

  • sudo apt install libopenmpi-dev openmpi-bin
  • hello.cpp
(注意:不用 include 以外的头文件,main 必须带 argc/argv,且第一行调 MPI_Init

编译运行:

  • mpicxx -o hello hello.cpp
  • mpirun -n 4 ./hello → 启动 4 个进程,输出 4 行带 rank 的问候

第二步:理解进程角色与基本通信模式

MPI 程序里没有“主从”概念,只有逻辑角色。常见分工方式:

立即学习C++免费学习笔记(深入)”;

Shakespeare
Shakespeare

一款人工智能文案软件,能够创建几乎任何类型的文案。

下载
  • rank 0 当协调者:读输入、分发任务、收集结果(比如读大数组,切块发给其他 rank)
  • 所有 rank 并行计算:各自处理本地数据块,再把局部结果归约(如求和、最大值)
  • 点对点通信慎用阻塞调用:避免死锁 —— 若 rank 0 发送、rank 1 接收,但 rank 1 先调 MPI_Recv 而 rank 0 还没 MPI_Send,就会卡住。建议用 MPI_Sendrecv 或非阻塞 MPI_Isend/MPI_Irecv + MPI_Wait

第三步:用集体通信做典型 HPC 操作

HPC 场景中,多数通信不是两两传,而是广播或归约。例如矩阵向量乘:

  • rank 0 把向量 b 广播给所有进程:MPI_Bcast(b, n, MPI_DOUBLE, 0, MPI_COMM_WORLD)
  • 各 rank 计算自己负责的几行 A[i][:] * b,得局部结果 local_y
  • MPI_Reduce(local_y, y, n, MPI_DOUBLE, MPI_SUM, 0, MPI_COMM_WORLD) 把所有局部结果加总到 rank 0 的 y

这些调用自动处理底层网络拓扑,你只管语义。

第四步:编译、调试与跨节点运行要点

单机多进程测试没问题后,扩展到多台机器只需:

  • 确保各节点安装相同版本 MPI,SSH 免密登录配置好
  • 用 hostfile 指定机器列表(如 node1 slots=4\nnode2 slots=4),运行:mpirun --hostfile hosts -n 8 ./your_app
  • 调试技巧:MPI_Comm_size 查总进程数,MPI_Get_processor_name 打印当前进程在哪台物理机上,方便定位负载不均问题

不复杂但容易忽略。

相关专题

更多
什么是分布式
什么是分布式

分布式是一种计算和数据处理的方式,将计算任务或数据分散到多个计算机或节点中进行处理。本专题为大家提供分布式相关的文章、下载、课程内容,供大家免费下载体验。

324

2023.08.11

分布式和微服务的区别
分布式和微服务的区别

分布式和微服务的区别在定义和概念、设计思想、粒度和复杂性、服务边界和自治性、技术栈和部署方式等。本专题为大家提供分布式和微服务相关的文章、下载、课程内容,供大家免费下载体验。

231

2023.10.07

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

480

2023.08.10

常见的linux系统有哪些
常见的linux系统有哪些

linux系统有Ubuntu、Fedora、CentOS、Debian、openSUSE、Arch Linux、Gentoo、Slackware、Linux Mint、Kali Linux。更多关于linux系统的文章详情请阅读本专题下面的文章。php中文网欢迎大家前来学习。

800

2023.10.27

ubunt上安装和配置vnc
ubunt上安装和配置vnc

安装方法:安装VNC服务器、启动VNC服务器、设置VNC密码等等。想了解更多ubuntu的相关内容,可以阅读本专题下面的文章。

409

2023.12.28

ubuntu启动黑屏解决方法
ubuntu启动黑屏解决方法

ubuntu启动黑屏解决方法:检查是否是电源问题、检查内存是否接触不良、检查显卡问题等。想了解更多ubuntu的相关内容,可以阅读本专题下面的文章。

656

2023.12.28

为什么ubuntu有网络连接但不能上网
为什么ubuntu有网络连接但不能上网

ubuntu有网络连接但不能上网的原因:1、dns配置问题;2、代理服务器设置问题;3、网络防火墙设置问题;4、路由器或调制解调器设置问题;5、网络驱动程序问题;6、网络配置文件问题;7、其他问题。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

452

2024.09.05

ubuntu安装golang
ubuntu安装golang

本专题整合了ubuntu安装golang所有方法汇总,阅读下面的文章了解更多详细操作。

105

2025.12.13

Golang gRPC 服务开发与Protobuf实战
Golang gRPC 服务开发与Protobuf实战

本专题系统讲解 Golang 在 gRPC 服务开发中的完整实践,涵盖 Protobuf 定义与代码生成、gRPC 服务端与客户端实现、流式 RPC(Unary/Server/Client/Bidirectional)、错误处理、拦截器、中间件以及与 HTTP/REST 的对接方案。通过实际案例,帮助学习者掌握 使用 Go 构建高性能、强类型、可扩展的 RPC 服务体系,适用于微服务与内部系统通信场景。

4

2026.01.15

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
HTML5/CSS3/JavaScript/ES6入门课程
HTML5/CSS3/JavaScript/ES6入门课程

共102课时 | 6.7万人学习

前端基础到实战(HTML5+CSS3+ES6+NPM)
前端基础到实战(HTML5+CSS3+ES6+NPM)

共162课时 | 18.8万人学习

第二十二期_前端开发
第二十二期_前端开发

共119课时 | 12.4万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号