簡體   English   中英

openmpi + java,找不到或加載主類

[英]openmpi + java, could not find or load main class

我最近正在嘗試openmpi庫的java綁定:

我已經使用以下配置成功編譯了lib:

$/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運行的任何想法?

由於包裝是:

package com.cyc115.pa2;

您需要將文件Main.java放在名為com/cyc115/pa2的子目錄中libmpi_java.so庫路徑應該是包含libmpi_java.so的目錄的路徑,而不是libmpi_java.so的路徑。

編譯:

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

以下不是問題,僅是僅供參考:

它應該是--with-jdk-headers和s,而不是--with-jdk-header但是如果您已經指定了--with-jdk-dir則不必完全指定它。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM