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

klsxnrf1  于 2021-06-02  发布在  Hadoop
关注(0)|答案(1)|浏览(351)

当我这样运行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创建的,windows的java版本是1.8,hadoop在ubuntu中运行,ubuntu的版本是1.6。
我认为这是安装在ubuntu上的java和从windows环境(我的例子)配置的jar不匹配,所以我在ubuntu中安装了java1.8版本并将其设为默认值。
现在输出 java -version 以及 javac -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

但问题依然存在。

gxwragnw

gxwragnw1#

好了,问题解决了,我忘了在conf文件中更改java主路径。
我做了,问题就解决了

相关问题