0、环境说明
1 2 |
1、本机系统为CentOS-7-x86_64-Minimal 2、使用的tomcat版本为: apache-tomcat-9.0.8.tar.gz |
1、情况说明
安装好tomcat之后,使用startup.sh脚本启动后,发现tomcat没有正常运行,查看日志有如下报错
安装好tomcat之后,使用startup.sh脚本启动后,发现tomcat没有正常运行,查看日志有如下报错
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 |
[root@imzcy logs]# more catalina.out 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.defineClass(ClassLoader.java:800) at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:142) at java.net.URLClassLoader.defineClass(URLClassLoader.java:449) at java.net.URLClassLoader.access$100(URLClassLoader.java:71) at java.net.URLClassLoader$1.run(URLClassLoader.java:361) at java.net.URLClassLoader$1.run(URLClassLoader.java:355) at java.security.AccessController.doPrivileged(Native Method) at java.net.URLClassLoader.findClass(URLClassLoader.java:354) at java.lang.ClassLoader.loadClass(ClassLoader.java:425) at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:308) at java.lang.ClassLoader.loadClass(ClassLoader.java:358) at sun.launcher.LauncherHelper.checkAndLoadMain(LauncherHelper.java:482) [root@imzcy logs]# |
2、排查2>
一般tomcat运行不需要依赖什么特别的包,只要配置好JDK就好了。于是检查以下几点发现java环境配置都正常
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 |
#2.1、检查/etc/profile文件配置 [root@imzcy ~]# tail -n 4 /etc/profile export JAVA_HOME=/usr/local/java export CLASSPATH=$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar export JRE_HOME=$JAVA_HOME/jre export PATH=$PATH:$JAVA_HOME/bin [root@imzcy ~]# #2.2、检查环境变量 [root@imzcy ~]# echo $PATH /usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/root/bin:/usr/local/java/bin:/usr/local/java/bin #2.3、检查java -version命令查看java版本 [root@imzcy ~]# java -version java version "1.7.0_80" Java(TM) SE Runtime Environment (build 1.7.0_80-b15) Java HotSpot(TM) 64-Bit Server VM (build 24.80-b11, mixed mode) |
重新解压tomcat包到其他位置发现也还是报错,百度搜了半天也没有找到解决方法,最后突然想到更换下jdk的版本(因为之前有跑公司jar包的时候发现不能用1.8的jdk,只能用1.7的。后来就默认使用1.7了),尝试更换现有java环境为1.8的jdk,没想到就正常。
1 2 3 4 5 6 7 8 9 10 11 |
[root@imzcy ~]# rm -rf /usr/local/java [root@imzcy ~]# rm -rf /usr/local/jdk1.7.0_80/ [root@imzcy ~]# tar zxvf jdk-8u171-linux-x64.tar.gz -C /usr/local/ [root@imzcy ~]# ln -s /usr/local/jdk1.8.0_171/ /usr/local/java [root@imzcy ~]# source /etc/profile [root@imzcy ~]# java -version java version "1.8.0_171" Java(TM) SE Runtime Environment (build 1.8.0_171-b11) Java HotSpot(TM) 64-Bit Server VM (build 25.171-b11, mixed mode) |
总结
安装使用9.0版本的tomcat时候,JDK要求不能使用低于1.8版本,不然启动就会报错。