当我运行我的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 -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
但问题仍然存在。
答案 0 :(得分:1)
我做到了,问题消失了