昨天突然发现自己的tomcat不好用了,具体就是tomcat无法启动,双击在%TOMCAT_HOME%\bin下的 startup.bat 文件,结果只是一闪而过,出现了dos窗口,但是只是一闪而过,然后什么反应都没有。
具体的错误没法描述,除非我使用视频把这个启动过程记录下来。总之启动不了了。
解决办法:
通过CMD进入DOS窗口,通过DOS窗口再触发这个startup文件,这时候DOS窗口就会记录下所有的信息,而不是一闪而过。我的具体错误信息是JDK路径有问题。于是在环境变量中重新设置JAVA_HOME(我原来设置了两个JDK),就可以正常启动了。
我的理解:
对于tomcat它是基于JDK的,启动tomcat的时候,它会自动的检查JDK,如何找不到正确的JDK,那么就会出现上面的情况,tomcat不能正常启动。
代码查看:
经过查看startup.bat代码,发现startup.bat文件会去触发catalina.bat文件,而catalina.bat文件会去触发 setclasspath.bat,setclasspath.bat文件会去检查JAVA_HOME和JRE_HOME,具体代码如下:其中我标注粗体 的为具体错误信息描述。
if not "%JAVA_HOME%" == "" goto gotJdkHome
if not "%JRE_HOME%" == "" goto gotJreHome
echo Neither the JAVA_HOME nor the JRE_HOME environment variable is defined
echo At least one of these environment variable is needed to run this program
goto exit
:gotJreHome
if not exist "%JRE_HOME%\bin\java.exe" goto noJavaHome
if not exist "%JRE_HOME%\bin\javaw.exe" goto noJavaHome
if not ""%1"" == ""debug"" goto okJavaHome
echo JAVA_HOME should point to a JDK in order to run in debug mode.
goto exit
:gotJdkHome
if not exist "%JAVA_HOME%\bin\java.exe" goto noJavaHome
if not exist "%JAVA_HOME%\bin\javaw.exe" goto noJavaHome
if not exist "%JAVA_HOME%\bin\jdb.exe" goto noJavaHome
if not exist "%JAVA_HOME%\bin\javac.exe" goto noJavaHome
if not "%JRE_HOME%" == "" goto okJavaHome
set JRE_HOME=%JAVA_HOME%
goto okJavaHome
:noJavaHome
echo The JAVA_HOME environment variable is not defined correctly
echo This environment variable is needed to run this program
echo NB: JAVA_HOME should point to a JDK not a JRE
goto exit
:okJavaHome
if not "%BASEDIR%" == "" goto gotBasedir
echo The BASEDIR environment variable is not defined
echo This environment variable is needed to run this program
goto exit
:gotBasedir
if exist "%BASEDIR%\bin\setclasspath.bat" goto okBasedir
echo The BASEDIR environment variable is not defined correctly
echo This environment variable is needed to run this program
goto exit
:okBasedir