java mpj,Win7下搭建JAVA並行開發環境MPJ Express(PART3)

2023-11-23 15:50

本文主要是介绍java mpj,Win7下搭建JAVA並行開發環境MPJ Express(PART3),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在前面的兩個PART中,我們分別搭建了並行開發環境,並小試牛刀實踐了簡單的並行開發。

http://blog.csdn.net/baimafujinji/article/details/45195159

http://blog.csdn.net/baimafujinji/article/details/45195285

當然在這個過程中,出現這樣或那樣的問題是在所難免的,這一部分我們就來討論一下其中可能會遇到的問題。

問題1:當我們搭建好開發環境后,我們需要試用一下mpjdaemon批處理命令,此時可能遇到的一個問題是: Port is not available,如下圖所示。

5cb5adad16f33412fbd725fd2aea375c.jpe

問題在於端口不可用。我們根據提示找到配置文件mpjexpress.conf所在的文件夾,然后用記事本把它打開,如下所示。可見,默認情況下port.1=10000,port.2=10001。

1453a9c6d0c0ff10733a00991d5051cc.jpe

此時,我們只需對端口進行調整,例如修改為下面這種結果(當然,應該保證8888和8889並沒有被占用)

8f1e75fd6c3e7278c489c5b53cfdd8a7.jpe

修改完成后保存文件,問題即得到解決。

問題2:注意到我們把解壓后的MPJ Express文件存於路徑“D:\mpj-v0_43”下,並相應的將環境變量MPJ_HOME賦值為D:\mpj-v0_43。如果我們將文件存於路徑“D:\Program Files\mpj-v0_43”下,並相應的修改環境變量賦值,將會有什么變化?

3aa4e97b464c25bb256549598079a1c1.jpe

這似乎是一個看起來完全不是問題的問題,但是一旦我們這樣做了,當再使用mpjdaemon批處理命令時,就會遇到下面這種情況。

f6423082cbd61bcfd7e7324c29e9ac4c.jpe

結果顯示報錯了!

Error: Unable to access jarfile D:\Program

系統沒有辦法訪問相應的jar文件。但是為什么?這是因為Program Files這個文件夾的名字不合法。這種文件夾的名字在Windows中當然沒有任何問題,對於我們日常的大多數應用開發而言這也不會成為一個問題。但是在MPJ Express中,文件夾的名字中間是不能包含有“空格”的。我們都知道,在控制台中輸入一條指令時,空格通常是用來間隔操作符與操作數的,或者可以認為空格也是有意義的,因此MPJ Express中的批處理命令在解析一個帶有空格的路徑名的時候就會產生混亂。這就是問題所在。所以只要我們把MPJ Express文件的存放路徑稍作調整即可消除此類問題。

此外,在命令行中查看當前環境變量設置情況的一個簡單方法是使用echo指令,例如

4f621e2d4fe55658b81cbe61376a6a09.jpe

問題3:上一個問題除了會發生在控制台操作界面上以外,在Eclipse中也會出現。回想在PART2中,我們設置VM arguments參數時是這樣寫的

-jar D:/mpj-v0_43/lib/starter.jar

-np 4

可見我們使用了一個絕對路徑!而更多的時候我們都習慣於寫相對路徑,此時用戶需要在菜單欄中選擇"Window",然后在下拉菜單中選擇"Preferences",如下所示。

064da1c71ade58c5537ddd8ddca42df7.jpe

然后在從左側的列表中選擇“String Substitution”,並新建一個“變量替換”,如下所示。

3fab24c2cae2360144e25adfbe303e25.jpe

完成上述步驟后,我們就可以使用形如下面這種情況的相對路徑了。

-jar ${MPJ_HOME}/lib/starter.jar

e2d9c156298a6a8b07a8c51174935ca0.jpe

這里我們需要注意,MPJ_HOME的值仍然不能等於一個有空格的路徑,否則就會出現下面這個錯誤,原理與問題2相同,這里不再贅述。

784112a9ad0245d1ba836fab21b8bf9d.jpe

問題4:最后我們討論一下在命令下編譯運行並行程序的方法。

首先編輯下列代碼並將其存入一個名為HelloWorld.java的文件中。

import mpi.*;

public class HelloWorld{

public static void main(String[] args) throws Exception

{

MPI.Init(args);

int me = MPI.COMM_WORLD.Rank();

int size = MPI.COMM_WORLD.Size();

System.out.println ("Hi from " + me + " of " + size + "\n");

MPI.Finalize();

}

}

編譯指令示例: javac -cp .;%MPJ_HOME%/lib/mpj.jar HelloWorld.java

執行指令示例: mpjrun.bat -np 4 HelloWorld  a //其中a是一個任意指定的參數

執行結果,如下所示。

bdfa24fa29390433f8c29c8b28bb268e.jpe

上面這種情況是執行並行計算的第一種場景,即在多核配置下執行MPJ Express 程序。

我們通過mpjrun.bat -np 后面的數字來指定核的數量。

另外一種場景是在集群(Cluster)配置下執行MPJ Express 程序。

集群配置: 如果開發人員期望在分布式內存平台(包括集群和計算機網絡)上執行並行JAVA程序,那么他們就會采樣這種配置場景。

對於這種集群配置,一共有四種選項,如下:

1) niodev - 使用 Java NIO Sockets

2) mxdev - 使用 Myrinet eXpress (MX) library for Myrinet networks

3) hybdev - 針對多核處理的集群

4) native - 使用一個 native MPI library (curretly only tested under MS-MPI for Windows)

具體使用時寫一個名為"machines"的文件,並在其中指定用於並發執行的所有主機名或IP地址。

執行方法

對於 niodev, hybdev and mxdev

1) 開啟守護: mpjdaemon.bat -boot

- 你將需要在每一個開啟守護的機器上手動地執行該命令。

2) 執行指令示例: mpjrun.bat -np 4 -dev niodev HelloWorld

-- 其中 -dev 里面的 device可以是 niodev, hybdev 或 mxdev

3) 終止守護指令: mpjdaemon.bat -halt

對於 native

1) 編譯 JNI wrapper library(具體編譯方法請參見MPJ Express的相關幫助文檔)

2) 執行指令示例: mpjrun.bat -np 4 -dev native HelloWorld

全文完。

这篇关于java mpj,Win7下搭建JAVA並行開發環境MPJ Express(PART3)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/419027

相关文章

springboot健康检查监控全过程

《springboot健康检查监控全过程》文章介绍了SpringBoot如何使用Actuator和Micrometer进行健康检查和监控,通过配置和自定义健康指示器,开发者可以实时监控应用组件的状态,... 目录1. 引言重要性2. 配置Spring Boot ActuatorSpring Boot Act

使用Java解析JSON数据并提取特定字段的实现步骤(以提取mailNo为例)

《使用Java解析JSON数据并提取特定字段的实现步骤(以提取mailNo为例)》在现代软件开发中,处理JSON数据是一项非常常见的任务,无论是从API接口获取数据,还是将数据存储为JSON格式,解析... 目录1. 背景介绍1.1 jsON简介1.2 实际案例2. 准备工作2.1 环境搭建2.1.1 添加

Java实现任务管理器性能网络监控数据的方法详解

《Java实现任务管理器性能网络监控数据的方法详解》在现代操作系统中,任务管理器是一个非常重要的工具,用于监控和管理计算机的运行状态,包括CPU使用率、内存占用等,对于开发者和系统管理员来说,了解这些... 目录引言一、背景知识二、准备工作1. Maven依赖2. Gradle依赖三、代码实现四、代码详解五

java如何分布式锁实现和选型

《java如何分布式锁实现和选型》文章介绍了分布式锁的重要性以及在分布式系统中常见的问题和需求,它详细阐述了如何使用分布式锁来确保数据的一致性和系统的高可用性,文章还提供了基于数据库、Redis和Zo... 目录引言:分布式锁的重要性与分布式系统中的常见问题和需求分布式锁的重要性分布式系统中常见的问题和需求

SpringBoot基于MyBatis-Plus实现Lambda Query查询的示例代码

《SpringBoot基于MyBatis-Plus实现LambdaQuery查询的示例代码》MyBatis-Plus是MyBatis的增强工具,简化了数据库操作,并提高了开发效率,它提供了多种查询方... 目录引言基础环境配置依赖配置(Maven)application.yml 配置表结构设计demo_st

在Ubuntu上部署SpringBoot应用的操作步骤

《在Ubuntu上部署SpringBoot应用的操作步骤》随着云计算和容器化技术的普及,Linux服务器已成为部署Web应用程序的主流平台之一,Java作为一种跨平台的编程语言,具有广泛的应用场景,本... 目录一、部署准备二、安装 Java 环境1. 安装 JDK2. 验证 Java 安装三、安装 mys

Springboot的ThreadPoolTaskScheduler线程池轻松搞定15分钟不操作自动取消订单

《Springboot的ThreadPoolTaskScheduler线程池轻松搞定15分钟不操作自动取消订单》:本文主要介绍Springboot的ThreadPoolTaskScheduler线... 目录ThreadPoolTaskScheduler线程池实现15分钟不操作自动取消订单概要1,创建订单后

JAVA中整型数组、字符串数组、整型数和字符串 的创建与转换的方法

《JAVA中整型数组、字符串数组、整型数和字符串的创建与转换的方法》本文介绍了Java中字符串、字符数组和整型数组的创建方法,以及它们之间的转换方法,还详细讲解了字符串中的一些常用方法,如index... 目录一、字符串、字符数组和整型数组的创建1、字符串的创建方法1.1 通过引用字符数组来创建字符串1.2

SpringCloud集成AlloyDB的示例代码

《SpringCloud集成AlloyDB的示例代码》AlloyDB是GoogleCloud提供的一种高度可扩展、强性能的关系型数据库服务,它兼容PostgreSQL,并提供了更快的查询性能... 目录1.AlloyDBjavascript是什么?AlloyDB 的工作原理2.搭建测试环境3.代码工程1.

Java调用Python代码的几种方法小结

《Java调用Python代码的几种方法小结》Python语言有丰富的系统管理、数据处理、统计类软件包,因此从java应用中调用Python代码的需求很常见、实用,本文介绍几种方法从java调用Pyt... 目录引言Java core使用ProcessBuilder使用Java脚本引擎总结引言python