在hadoop中执行.jar文件时出现Java版本错误

时间:2013-02-09 01:21:15

标签: java hadoop

我使用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安装档案,除了一个(hadoop-core),我必须从MavenRepository(http://mvnrepository.com/artifact/org.apache.hadoop/hadoop-core)手动下载。我下载了1.0.4版本,这是我使用的Hadoop版本。

总而言之,事情似乎与我很相容,但我再次使用Hadoop,我希望能够对这个问题有所了解。

1 个答案:

答案 0 :(得分:0)

为什么不在主机本身编译源文件并将它们打包到Jar中。你可以运行以下命令:

  1. 将所有Java文件复制到目录。
  2. mkdir classes
  3. javac -classpath <path_to_hadoop_library_jars_separated_by_colon_if_more_than_one> -d classes *.java
  4. jar -cvf myjar.jar -C classes/ .
  5. 现在尝试运行此JAR。让我们看看它是否有效。