我已经使用 Java/NetBeans 实现了一个 pagerank 算法,并且我已经构建了 .jar 文件以在 hadoop 中执行它。
在尝试执行它时,我遇到了这个错误:
Exception in thread "main" java.lang.UnsupportedClassVersionError: Pagerank : Unsupported major.minor version 51.0
at java.lang.ClassLoader.defineClass1(Native Method)
at java.lang.ClassLoader.defineClassCond(ClassLoader.java:631)
at java.lang.ClassLoader.defineClass(ClassLoader.java:615)
at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:141)
at java.net.URLClassLoader.defineClass(URLClassLoader.java:283)
at java.net.URLClassLoader.access$000(URLClassLoader.java:58)
at java.net.URLClassLoader$1.run(URLClassLoader.java:197)
at java.security.AccessController.doPrivileged(Native Method)
at java.net.URLClassLoader.findClass(URLClassLoader.java:190)
at java.lang.ClassLoader.loadClass(ClassLoader.java:306)
at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:301)
at java.lang.ClassLoader.loadClass(ClassLoader.java:295)
at java.lang.ClassLoader.loadClass(ClassLoader.java:247)
at java.lang.Class.forName0(Native Method)
at java.lang.Class.forName(Class.java:247)
at org.apache.hadoop.util.RunJar.main(RunJar.java:149)
经过一番搜索,我发现可能存在 Java 版本兼容性问题。现在我使用带有 Java 1.6 的 hadoop 1.04 版本。我更改了我的 NetBeans 项目以使用相同的版本。
关于我在项目中包含的一些 .jar 库,所有这些库都取自我的 hadoop 安装档案,除了我必须从 MavenRepository 手动下载的一个(hadoop-core)(http://mvnrepository.com/artifact/org.apache .hadoop/hadoop-core)。我下载了 1.0.4 版本,这是我使用的 Hadoop 版本。
尽管如此,事情对我来说似乎很兼容,但是我再次使用 Hadoop,我希望我能对这个问题有所了解。