openmpi + java,无法找到或加载主 class

openmpi + java, could not find or load main class

我最近正在试用 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/

但是我无法将 class 文件传输到 运行。以下是我迄今为止尝试过的一些替代方案:

$java -Djava.library.path=/home/yuechuan/Application/.openmpi/lib/mpi.jar -cp .:/home/yuechuan/Application/.openmpi/lib/mpi.jar Main

其中 returns Error: Could not find or load main class Main 错误。

纯粹而简单的$java Main命令returnsNoClassDefFoundError

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 转换为 运行 有什么想法吗?

因为包裹是:

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-header--with-jdk-headers,但是如果您已经指定 --with-jdk-dir.

,则根本不必指定它