Vuze (Azureus) の最新バージョンをインストールした後、起動しようとすると奇妙なエラーが発生しました。
> java -Xmx128m -classpath ./Azureus2.jar:./swt.jar -Djava.library.path=/bt_work/vuze -Dazureus.install.path=/bt_work/vuze -Dazureus.script=./azureus -Dazureus.script.version=2 org.gudy.azureus2.ui.swt.Main
Exception in thread "main" java.lang.NoClassDefFoundError: org/gudy/azureus2/ui/swt/Main
Caused by: java.lang.ClassNotFoundException: org.gudy.azureus2.ui.swt.Main
at java.net.URLClassLoader$1.run(URLClassLoader.java:202)
奇妙なのはこれです:
> javap -classpath ./Azureus2.jar:./swt.jar org.gudy.azureus2.ui.swt.Main
Compiled from "Main.java"
public class org.gudy.azureus2.ui.swt.Main extends java.lang.Object{
public static final java.lang.String PR_MULTI_INSTANCE;
...
だから...javap
同じクラスパスで実行するとクラスが見つかりますが、java
単独ではできません。何が起きてんだ?
両方のプログラムが同じインストール Java ( /usr/lib64/jvm/java-1.6.0-sun
) から来ていることを確認しました。これは Java 6 であり、クラスは Java 5 用にコンパイルされています。マニフェストは署名されていません。JAR ファイルは読み取り可能です (unzip -t
エラーは報告されません)。