java.lang.UnsupportedClassVersionError : Unsupported major.minor version 52.0

在spark-shell中,遇到了如下的错误:

Caused by: java.lang.UnsupportedClassVersionError: xxx/xxx/xxx/xxx : Unsupported major.minor version 52.0
  at java.lang.ClassLoader.defineClass1(Native Method)
  at java.lang.ClassLoader.defineClass(ClassLoader.java:800)
  at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:142)
  at java.net.URLClassLoader.defineClass(URLClassLoader.java:449)
...

经过一番思考与搜索,发现这种情况是java版本不一致造成的。参考Wikipedia Java Class Reference

J2SE 9 = 53
J2SE 8 = 52
J2SE 7 = 51
J2SE 6.0 = 50
J2SE 5.0 = 49
JDK 1.4 = 48
JDK 1.3 = 47
JDK 1.2 = 46
JDK 1.1 = 45

以上是java的主要版本分配的数字。这个错误是由于编译的时候JDK版本比运行时候的JDK版本高造成的。
那解决的方法就很简单了,将运行时JDK版本指定为编译时的JDK版本,两者保持一致即可。

具体到spark-shell中,加入配置项:--java 8,指定jdk的版本为8,即可完美解决。

参考文献:
1.Wikipedia Java Class Reference https://en.wikipedia.org/wiki/Java_class_file
2.https://stackoverflow.com/questions/22489398/unsupported-major-minor-version-52-0

猜你喜欢

转载自blog.csdn.net/bitcarmanlee/article/details/79035735