關於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安裝參考