news 2026/3/29 18:38:50

适用于Rocky Linux的MPI 管理程序

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
适用于Rocky Linux的MPI 管理程序

某些场景下需要在节点上同时部署openmpi和mpich,根据需要决定使用哪种。此时若有一种方法可以进行轻松切换则会极其便捷。

故而文中方法应运而生

文件 1:配置文件

路径:/etc/mpi-manager/mpi.conf

MPI_IMPLEMENTATION=openmpi

文件 2:自动加载脚本

路径:/etc/profile.d/mpi.sh

# /etc/profile.d/mpi.sh - Auto MPI loader (Default: OpenMPI) # 读取配置 [[ -f /etc/mpi-manager/mpi.conf ]] && source /etc/mpi-manager/mpi.conf || MPI_IMPLEMENTATION=openmpi # 检测架构并映射到模块名 case "$(uname -m)" in x86_64) ARCH=x86_64 ;; aarch64|arm64) ARCH=aarch64 ;; ppc64le) ARCH=ppc64le ;; ppc64) ARCH=ppc64 ;; s390x) ARCH=s390x ;; riscv64) ARCH=riscv64 ;; *) ARCH=x86_64 ;; esac # 模块映射表 case "${MPI_IMPLEMENTATION}_${ARCH}" in mpich_x86_64) MODULE=mpi/mpich-x86_64 ;; mpich_aarch64) MODULE=mpi/mpich-aarch64 ;; mpich_ppc64le) MODULE=mpi/mpich-ppc64le ;; mpich_ppc64) MODULE=mpi/mpich-ppc64 ;; mpich_s390x) MODULE=mpi/mpich-s390x ;; mpich_riscv64) MODULE=mpi/mpich-riscv64 ;; openmpi_x86_64) MODULE=mpi/openmpi-x86_64 ;; openmpi_aarch64) MODULE=mpi/openmpi-aarch64 ;; openmpi_ppc64le) MODULE=mpi/openmpi-ppc64le ;; openmpi_ppc64) MODULE=mpi/openmpi-ppc64 ;; openmpi_s390x) MODULE=mpi/openmpi-s390x ;; openmpi_riscv64) MODULE=mpi/openmpi-riscv64 ;; mpich_*) MODULE=mpi/mpich ;; openmpi_*) MODULE=mpi/openmpi ;; *) MODULE=mpi/openmpi ;; esac # 加载模块(如果module命令可用) if command -v module >/dev/null 2>&1; then module purge >/dev/null 2>&1 module load "$MODULE" >/dev/null 2>&1 || echo "MPI module $MODULE not available" fi # 设置基本变量 export MPI_IMPL=$MPI_IMPLEMENTATION export MPI_ARCH=$ARCH export MPI_MODULE=$MODULE # 便利命令 mpi-status() { echo "MPI: $MPI_IMPL ($MPI_ARCH)" echo "Module: $MODULE" command -v module >/dev/null 2>&1 && module list | grep -i mpi || echo "Module command not available" }

文件 3:设置工具

路径:/usr/local/bin/mpi-set

#!/bin/bash # Set MPI implementation if [[ $# -ne 1 ]] || [[ "$1" != "mpich" && "$1" != "openmpi" ]]; then echo "Usage: $0 {mpich|openmpi}" current=$(grep MPI_IMPLEMENTATION /etc/mpi-manager/mpi.conf 2>/dev/null | cut -d'=' -f2) echo "Current: ${current:-openmpi}" exit 1 fi echo "MPI_IMPLEMENTATION=$1" > /etc/mpi-manager/mpi.conf echo "MPI set to: $1" echo "New logins will use $1 automatically"

文件 4:安装脚本

路径:/usr/local/sbin/install-mpi-manager

#!/bin/bash # One-step robust installation (Default: OpenMPI) set -e # 创建文件 sudo mkdir -p /etc/mpi-manager echo "MPI_IMPLEMENTATION=openmpi" | sudo tee /etc/mpi-manager/mpi.conf >/dev/null # 创建自动加载脚本 sudo tee /etc/profile.d/mpi.sh >/dev/null << 'EOF' # /etc/profile.d/mpi.sh - Auto MPI loader (Default: OpenMPI) [[ -f /etc/mpi-manager/mpi.conf ]] && source /etc/mpi-manager/mpi.conf || MPI_IMPLEMENTATION=openmpi case "$(uname -m)" in x86_64) ARCH=x86_64 ;; aarch64|arm64) ARCH=aarch64 ;; ppc64le) ARCH=ppc64le ;; ppc64) ARCH=ppc64 ;; s390x) ARCH=s390x ;; riscv64) ARCH=riscv64 ;; *) ARCH=x86_64 ;; esac case "${MPI_IMPLEMENTATION}_${ARCH}" in mpich_x86_64) MODULE=mpi/mpich-x86_64 ;; mpich_aarch64) MODULE=mpi/mpich-aarch64 ;; mpich_ppc64le) MODULE=mpi/mpich-ppc64le ;; mpich_ppc64) MODULE=mpi/mpich-ppc64 ;; mpich_s390x) MODULE=mpi/mpich-s390x ;; mpich_riscv64) MODULE=mpi/mpich-riscv64 ;; openmpi_x86_64) MODULE=mpi/openmpi-x86_64 ;; openmpi_aarch64) MODULE=mpi/openmpi-aarch64 ;; openmpi_ppc64le) MODULE=mpi/openmpi-ppc64le ;; openmpi_ppc64) MODULE=mpi/openmpi-ppc64 ;; openmpi_s390x) MODULE=mpi/openmpi-s390x ;; openmpi_riscv64) MODULE=mpi/openmpi-riscv64 ;; mpich_*) MODULE=mpi/mpich ;; openmpi_*) MODULE=mpi/openmpi ;; *) MODULE=mpi/openmpi ;; esac if command -v module >/dev/null 2>&1; then module purge >/dev/null 2>&1 module load "$MODULE" >/dev/null 2>&1 || echo "MPI module $MODULE not available" fi export MPI_IMPL=$MPI_IMPLEMENTATION export MPI_ARCH=$ARCH export MPI_MODULE=$MODULE mpi-status() { echo "MPI: $MPI_IMPL ($MPI_ARCH)" echo "Module: $MODULE" command -v module >/dev/null 2>&1 && module list | grep -i mpi || echo "Module command not available" } EOF # 创建设置工具 sudo tee /usr/local/bin/mpi-set >/dev/null << 'EOF' #!/bin/bash if [[ $# -ne 1 ]] || [[ "$1" != "mpich" && "$1" != "openmpi" ]]; then echo "Usage: $0 {mpich|openmpi}" current=$(grep MPI_IMPLEMENTATION /etc/mpi-manager/mpi.conf 2>/dev/null | cut -d'=' -f2) echo "Current: ${current:-openmpi}" exit 1 fi echo "MPI_IMPLEMENTATION=$1" > /etc/mpi-manager/mpi.conf echo "MPI set to: $1" EOF # 设置权限 sudo chmod 644 /etc/mpi-manager/mpi.conf /etc/profile.d/mpi.sh sudo chmod 755 /usr/local/bin/mpi-set echo "Installation completed! (Default: OpenMPI)" echo "Config: /etc/mpi-manager/mpi.conf" echo "Current: $(grep MPI_IMPLEMENTATION /etc/mpi-manager/mpi.conf)" echo "" echo "Usage:" echo " mpi-set mpich # Switch to MPICH" echo " mpi-set openmpi # Switch to OpenMPI (default)" echo " source /etc/profile" echo " mpi-status"

文件 5:卸载脚本(可选)

路径:/usr/local/sbin/uninstall-mpi-manager

#!/bin/bash sudo rm -f /etc/mpi-manager/mpi.conf sudo rm -f /etc/profile.d/mpi.sh sudo rm -f /usr/local/bin/mpi-set echo "Uninstalled"

安装和使用

安装

sudo /usr/local/sbin/install-mpi-manager

切换 MPI 实现

sudo mpi-set mpich # 切换到 MPICH sudo mpi-set openmpi # 切换到 OpenMPI(默认)

生效和使用

# 新登录自动生效(默认 OpenMPI) # 当前 shell 生效: source /etc/profile # 查看状态: mpi-status
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/24 4:09:21

万字亿集流量系统架构总结笔记(下)

6通用计数系统 在进行各类计数数据的展示时&#xff0c;初学者非常容易直白地认为数据的统计计数应该来源 于数据记录本身。比如点赞数可以从作品点赞记录数据中统计总数得到&#xff0c;评论数可以从作 品评论记录中统计总数得到……实际上&#xff0c;这样的做法有极大的并发…

作者头像 李华
网站建设 2026/3/29 6:01:06

【课程设计/毕业设计】基于springboot的大型超市购物管理系统基于springboot的线上超市购物管理系统的设计与实现【附源码、数据库、万字文档】

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华
网站建设 2026/3/28 17:00:10

【计算机毕业设计案例】基于springboot的眼科医院管理系统基于SpringBoot+Vue的眼科患者随访管理系统(程序+文档+讲解+定制)

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华
网站建设 2026/3/14 9:30:18

高效完成开题报告:9款人工智能写作工具与模板修改技巧

工具对比速览 工具名称 核心功能 适用场景 效率评分 特色优势 AIBiYe 开题报告生成/降重 中文论文全流程 ★★★★★ 国内院校适配度高 AICheck 初稿生成/格式检查 快速产出框架 ★★★★☆ 结构化输出优秀 AskPaper 文献综述辅助 外文文献处理 ★★★★ 跨…

作者头像 李华
网站建设 2026/3/21 3:34:33

9组AI增强型工具组合,专为毕业论文开题报告修改设计

工具对比速览 工具名称 核心功能 适用场景 效率评分 特色优势 AIBiYe 开题报告生成/降重 中文论文全流程 ★★★★★ 国内院校适配度高 AICheck 初稿生成/格式检查 快速产出框架 ★★★★☆ 结构化输出优秀 AskPaper 文献综述辅助 外文文献处理 ★★★★ 跨…

作者头像 李华
网站建设 2026/3/18 13:31:13

导师推荐10个AI论文平台,研究生高效写作必备!

导师推荐10个AI论文平台&#xff0c;研究生高效写作必备&#xff01; AI工具如何助力论文写作&#xff0c;让科研更高效 在当前学术研究日益数字化的背景下&#xff0c;AI工具已经成为研究生和科研工作者不可或缺的助手。尤其是在论文写作过程中&#xff0c;AI不仅能够提升效率…

作者头像 李华