0

我为 map-reduce 应用程序创建了一个自定义 jar,并尝试在 Amazon EMR 作业流中运行它。我在 hadoop 1.0.4 中编译了代码,但是 Amazon EMR 支持 Hadoop 1.0.3。另外我在 jdk 1.7 下编译了代码,我不确定 Amazon EMR 使用哪个版本的 java,我们可以在哪里更改它?

这是堆栈跟踪

Exception in thread "main" java.lang.UnsupportedClassVersionError: com/test/GWASMapReduce : 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 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:180)
4

4 回答 4

3

Amazon EMR 似乎不支持 Java 7。您需要尝试编译您的 jar 以针对较旧的 JVM:

javac -target 1.6 -cp .... etc
于 2012-11-07T23:22:56.223 回答
0

根据 Muel,Amazon EMR 不支持 Java 7,截至今天,Amazon EMR 支持版本 1.0.3、0.20.205。

于 2012-11-08T15:33:39.387 回答
0

EMR 平台仍然不支持 Java 7,请参见此处

于 2013-08-23T12:05:04.627 回答
0

它现在支持了一段时间。最低为 AMI 版本 2.4。请参阅http://docs.aws.amazon.com/ElasticMapReduce/latest/DeveloperGuide/ami-versions-supported.html

于 2014-11-24T09:36:46.363 回答