hadoop map reduce程序没有运行不支持的major.minor版本

时间:2014-10-14 07:45:08

标签: java hadoop mapreduce hdfs

当我运行我的MapReduce程序时:

bin/hadoop jar /usr/local/hadoop/share/hadoop/mapreduce/mapreduceprog.jar problemdata /problemdata/input2 /problemdata/output5

我得到以下输出:

 Exception in thread "main" java.lang.UnsupportedClassVersionError: mapreduceprog : Unsupported major.minor version 52.0
    at java.lang.ClassLoader.defineClass1(Native Method)
    at java.lang.ClassLoader.defineClass(ClassLoader.java:643)
    at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:142)
    at java.net.URLClassLoader.defineClass(URLClassLoader.java:277)
    at java.net.URLClassLoader.access$000(URLClassLoader.java:73)
    at java.net.URLClassLoader$1.run(URLClassLoader.java:212)
    at java.security.AccessController.doPrivileged(Native Method)
    at java.net.URLClassLoader.findClass(URLClassLoader.java:205)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:323)
    at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:294)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:316)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:268)
    at java.lang.Class.forName0(Native Method)
    at java.lang.Class.forName(Class.java:270)
    at org.apache.hadoop.util.RunJar.main(RunJar.java:2as 

jar文件是从windows中的netbeans创建的,其中java版本为1.8,hadoop在ubuntu中运行,版本为1.6。

我认为这是在ubuntu上安装的java和从windows环境(我的情况)配置的jar之间的不匹配, 所以我在ubuntu中安装了java 1.8版本并将其设为默认版本。

现在java -versionjavac -version的输出如下:

java -version
java version "1.8.0_20"
Java(TM) SE Runtime Environment (build 1.8.0_20-b26)
Java HotSpot(TM) Client VM (build 25.20-b23, mixed mode)


javac -version
javac 1.8.0_20

但问题仍然存在。

1 个答案:

答案 0 :(得分:1)

好的家伙问题解决了 我忘了在conf文件中更改tha家庭路径。

我做到了,问题消失了