openmpi + java,找不到或加载主类
Posted
技术标签:
【中文标题】openmpi + java,找不到或加载主类【英文标题】:openmpi + java, could not find or load main class 【发布时间】:2016-01-16 08:14:01 【问题描述】:我最近正在尝试 openmpi 库的 java 绑定:
我已经成功编译了以下配置的库:
$/configure --prefix "/home/yuechuan/Application/.openmpi" --enable-mpi-java --with-jdk-dir="/usr/lib/jvm/java-8-oracle/" --with-jdk-header="/usr/lib/jvm/java-8-oracle/include/"
$sudo make install
我可以编译一个简单的 java 程序:$mpijavac src/com/cyc115/pa2/Main.java
目前$echo $CLASSPATH
提供/home/yuechuan/Github/parallel_pa2/src/com/cyc115/pa2/
但是我无法让类文件运行。以下是我迄今为止尝试过的一些替代方案:
$java -Djava.library.path=/home/yuechuan/Application/.openmpi/lib/mpi.jar -cp .:/home/yuechuan/Application/.openmpi/lib/mpi.jar Main
返回 Error: Could not find or load main class Main
错误。
纯粹的$java Main
命令返回NoClassDefFoundError
Error: A JNI error has occurred, please check your installation and try again
Exception in thread "main" java.lang.NoClassDefFoundError: mpi/MPIException
at java.lang.Class.getDeclaredMethods0(Native Method)
at java.lang.Class.privateGetDeclaredMethods(Class.java:2701)
at java.lang.Class.privateGetMethodRecursive(Class.java:3048)
at java.lang.Class.getMethod0(Class.java:3018)
at java.lang.Class.getMethod(Class.java:1784)
at sun.launcher.LauncherHelper.validateMainClass(LauncherHelper.java:544)
at sun.launcher.LauncherHelper.checkAndLoadMain(LauncherHelper.java:526)
Caused by: java.lang.ClassNotFoundException: mpi.MPIException
at java.net.URLClassLoader.findClass(URLClassLoader.java:381)
at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:331)
at java.lang.ClassLoader.loadClass(ClassLoader.java:357)
... 7 more
如果有人需要,这里是 java 文件:
package com.cyc115.pa2;
import mpi.MPI;
import mpi.MPIException;
public class Main
public static void main(String args[]) throws MPIException
MPI.Init(args);
int rank = MPI.COMM_WORLD.getRank();
int size = MPI.COMM_WORLD.getSize();
System.out.print("hello world");
MPI.Finalize();
关于如何让 .class 运行的任何想法?
【问题讨论】:
【参考方案1】:因为包裹是:
package com.cyc115.pa2;
您需要将文件 Main.java 放在名为 com/cyc115/pa2
的子目录中
java库路径应该是包含libmpi_java.so
的目录的路径,而不是mpi.jar的路径。
编译:
javac -cp /home/yuechuan/Application/.openmpi/lib/mpi.jar com/cyc115/pa2/Main.java
运行:
java -Djava.library.path=/home/yuechuan/Application/.openmpi/lib/ -cp .:/home/yuechuan/Application/.openmpi/lib/mpi.jar com.cyc115.pa2.Main
以下不是问题,仅供参考:
它应该是带有 s 的 --with-jdk-headers
而不是 --with-jdk-header
但是,如果您已经指定了 --with-jdk-dir
,则根本不必指定它。
【讨论】:
注意这正确地有 java.library.path 作为目录,而不是问题的 jar 文件。以上是关于openmpi + java,找不到或加载主类的主要内容,如果未能解决你的问题,请参考以下文章