关于Unsupported major.minor version 52.0异常处理总结
导致本次问题是因为linux系统安装了两种版本jdk(6和8)导致,系统中生效的jdk是1.6版本,而不是1.8(虽然jdk1.8页配置环境变量,但起作用的依然是jdk1.6),导致tomcat9无法启动
Exception in thread "main" java.lang.UnsupportedClassVersionError: org/apache/catalina/startup/Bootstrap : Unsupported major.minor version 52.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 sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:301)
at java.lang.ClassLoader.loadClass(ClassLoader.java:247)
Could not find the main class: org.apache.catalina.startup.Bootstrap. Program will exit.
#上述异常原因是:当前要运行的程序编译时使用的jdk版本过高(jdk8),而本地linux环境运行起作用的jdk版本过低(jdk6)导致,
并不是linux系统环境jdk版本过高导致程序无法启动。系统运行环境高版本的jdk会兼容用低版本jdk进行编译的程序,
所以出现此种问题不要降低系统jdk的版本。
#排查过程:1.运行java -version, 发现版本确实是1.8,按照理论确实是可以运行tomcat9的,但实际情况当前系统生效的jdk并不 是1.8,
所以java -version并不代表程序运行使用的就是jdk1.8
2. 查找能够配置jdk环境变量的地方(/etc/profile,~/.bashrc),发现在bashrc中配置了jdk1.6,所以系统中存在两个版本的jdk,而且生效的是1.6。
进入该文件bashrc删除1.6的配置。再次运行tomcat,正常启动
通过yum安装的jdk,可以不用配置环境变量
#JDK版本与major.minor version的对照关系
序号 jdk版本 major.minor version
1 1.1 45
2 1.2 46
3 1.3 47
4 1.4 48
5 5 49
6 6 50
7 7 51
8 8 52
linux jdk安装参考