linux tomcat 启动报错Unsupported major.minor version 51.0

linux服务器启动tomcat(从官网下载的未启动过的包,未作任何配置,修改了/conf/server.xml端口号)

./startup.sh

打印得到以下信息(老代码,使用的jdk版本较低):

Using CATALINA_BASE:   /xxx/xxx/xxx/apache-tomcat-8.5.79
Using CATALINA_HOME:   /xxx/xxx/xxx/apache-tomcat-8.5.79
Using CATALINA_TMPDIR: /xxx/xxx/xxx/apache-tomcat-8.5.79/temp
Using JRE_HOME:        /xxx/jdk1.6.0_45
Using CLASSPATH:       /xxx/xxx/xxx/apache-tomcat-8.5.79/bin/bootstrap.jar:/xxx/xxx/xxx/apache-tomcat-8.5.79/bin/tomcat-juli.jar
Using CATALINA_OPTS:   
Tomcat started.
ps -ef | grep tomcat  ## 以为起起来了,结果一看没有
tail -1000 ../logs/catalina.out

发现以下报错:

Exception in thread "main" java.lang.UnsupportedClassVersionError: org/apache/catalina/startup/Bootstrap : 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 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.

接着检查:

java -version
javac -version  ## 对比java和javac的版本是否一致
cat /etc/profile ## 查看环境变量JAVA_HOME

## 以上三个检查和启动时打印的参数有问题,需指定tomcat启动jdk版本
## 在/bin/setclasspath.sh和/bin/catalina.sh中注释的后面正文的第一行加入以下两个:
 export JAVA\_HOME=/usr/java/jdk1.8.0\_45  
 export JRE\_HOME=/usr/java/jdk1.8.0\_45/jre
 
## 注意:"=" 左右两边不要有空格,否则会报错!!!!!

## 重启tomcat,打印的参数中JRE_HOME是刚刚配置的路径

在尝试了指定jdk版本后,仍然是一样的报错,网上一查,发现不是jdk版本的问题。
在tomcat官网发现tomcat8最低支持jdk7:
linux tomcat 启动报错Unsupported major.minor version 51.0_第1张图片

总结:
UnsupportedClassVersionError通常是由于较低版本jdk编译得到的class文件试图在较高版本的JVM中运行导致的。
解决办法要么升级jdk,并重新编译项目;要么降低tomcat版本。

结果copy了原tomcat的server.xml到tomcat7中,启动时报错java.lang.ClassNotFoundException: org.apache.catalina.mbeans.ServerLifecycleListener。
解决办法:
6.0.18以前,conf/server.xml里面的配置有这项

<Listener className="org.apache.catalina.mbeans.ServerLifecycleListener" />

注释掉就可以了

<!--<Listener className="org.apache.catalina.mbeans.ServerLifecycleListener" /> -->

你可能感兴趣的:(#,中间件,tomcat,linux,java)