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

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

当我这样运行mapreduce程序时:

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

我得到以下输出:

  1. Exception in thread "main" java.lang.UnsupportedClassVersionError: mapreduceprog : Unsupported major.minor version 52.0
  2. at java.lang.ClassLoader.defineClass1(Native Method)
  3. at java.lang.ClassLoader.defineClass(ClassLoader.java:643)
  4. at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:142)
  5. at java.net.URLClassLoader.defineClass(URLClassLoader.java:277)
  6. at java.net.URLClassLoader.access$000(URLClassLoader.java:73)
  7. at java.net.URLClassLoader$1.run(URLClassLoader.java:212)
  8. at java.security.AccessController.doPrivileged(Native Method)
  9. at java.net.URLClassLoader.findClass(URLClassLoader.java:205)
  10. at java.lang.ClassLoader.loadClass(ClassLoader.java:323)
  11. at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:294)
  12. at java.lang.ClassLoader.loadClass(ClassLoader.java:316)
  13. at java.lang.ClassLoader.loadClass(ClassLoader.java:268)
  14. at java.lang.Class.forName0(Native Method)
  15. at java.lang.Class.forName(Class.java:270)
  16. 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 具体如下:

  1. java -version
  2. java version "1.8.0_20"
  3. Java(TM) SE Runtime Environment (build 1.8.0_20-b26)
  4. Java HotSpot(TM) Client VM (build 25.20-b23, mixed mode)
  5. javac -version
  6. javac 1.8.0_20

但问题依然存在。

gxwragnw

gxwragnw1#

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

相关问题