最近由于Java开发环境由eclipse换成idea,发现了一些很奇特的问题。遂写下来和大家分享下。

开发使用环境为(64位版)idea2017.3月版本+jdk9+tomcat9,发现之前配置好的tomcat不能使用了。

先说方法:将jdk从版本9更换为jdk8。如果有兴趣接着往下看即可。

排错过程如下:

之前eclipse使用的是32为的tomcat7,先将tomcat7换成64位后发现tomcat还不能正常使用,于是将tomcat更换成最新版本tomcat9。发现使用cmd命令启动tomcat安装目录/bin/startup.bat还是无法启动tomcat。

可以右键点击startup.bat,编辑,在文本的最后敲上pause,保存后重新运行startup.bat,这时候窗口不会再一闪而过,而是停留在桌面上(调试成功,把pause去掉即可)。

java 安装 闪退 java打开后闪退_Code

再次打开startup.bat文件会出现如下信息。

java 安装 闪退 java打开后闪退_java 安装 闪退_02

首先排除如下问题:tomcat的环境变量配置问题。结论:tomcat的环境变量在运行的时候就自动配上了。(原因在最后)。

接着考虑如下问题:端口问题(由于没有报错,所以这里不写,仅作提醒)、环境变量中path,Java的环境变量是不是放在最前面。另外可以在startup.bat文件的第一行后面添加一句话:set JAVA_HOME=[jdk安装目录]D("[ ]"去掉)。如图

java 安装 闪退 java打开后闪退_Code_03

再次使用cmd命令启动startup.bat文件后会出现很多信息,如图

java 安装 闪退 java打开后闪退_java 安装 闪退_04

之后在浏览器涨输入“http://localhost:8080/”发现还是不能启动tomcat服务器。

考虑如下问题:由于没有报错,是否是已经启动,却将tomcat服务关闭掉(由于这里没有出现类似问题,仅作提醒用)、或者是tomcat服务已经启动了,但是却没有正常启动、或者是之前配置有问题(已经排除)。这里重点考虑是否是没有正常启动,于是尝试使用cmd命令结束tomcat服务。在cmd命令界面中进入tomcat的bin目录,启动shutdown.bat文件,发现报错,欣喜若狂。因为终于报错了。如图

java 安装 闪退 java打开后闪退_后端_05

发现是一个很简单的Java虚拟机的参数错误,于是按照传统方法更改之后(这里放一个传送门:虚拟机参数错误),再次使用shutdown.bat命令发现问题依然存在。发现问题没有那么简单。经过一番科学搜索之后,终于在Oracle官网找到了答案。(传送门:Oracle官网说明)如图

java 安装 闪退 java打开后闪退_java 安装 闪退_06

chrome翻译如下:

java 安装 闪退 java打开后闪退_java_07

所以,我们尝试将jdk版本从jdk9更换到jdk8中,启动tomcat服务。

java 安装 闪退 java打开后闪退_Code_08

ok大功告成,撒花。旁边的人拍了拍我的肩膀,上午干啥了,答曰:在启动tomcat服务

************分割线************

一、其实在idea中我们可以不用配置tomcat服务也可以正常进行Java Web开发,但是在配置JRebel for IntellIj之后会出现一个 错似曾相识的错误,如图:

java 安装 闪退 java打开后闪退_java_09

那么,我们配置完tomcat之后可以启动了吗?

答案是不能!如图:

java 安装 闪退 java打开后闪退_后端_10

还是会出现:JRebel-JVMTI [ERROR] Process finished with exit code 1,

打开日志发现。Application Server was not connected before run configuration stop, reason:

Unable to ping server at localhost:1099

解决思路是:JRE_HOME没有配置,或编译器使用的jre版本是不正确的。还是同样的思路,我们在配置完JRE_HOME变量后,一定要配置一遍jre版本。如图

run–>Edit Configurations选择jre版本为8的。完美解决,如图。

java 安装 闪退 java打开后闪退_tomcat_11

二、解释下为什么配置tomcat的时候不用配置tomcat的环境变量,结论:

1、判断CATALINA_HOME是否为空,为空则把当前目录设为CATALINA_HOME的值;

2、再判断catalina.bat是否存在,不存在则把当前目录设为CATALINA_HOME的值;

3、再判断环境变量下的catalina.bat是否存在,存在则调用bin目录下的“catalina.bat start”命令~

我们找到startup.bat文件,鼠标右键点击编辑,看到里面的内容:

rem Guess CATALINA_HOME if not defined		//为注释代码:判断 CATALINA_HOME 环境变量是否已经配置
set "CURRENT_DIR=%cd%"				//设置CURRENT_DIR 变量(当前工作目录)为:D:Code	omcat9in 
if not "%CATALINA_HOME%" == "" goto gotHome	//如果配置了 CATALINA_HOME 环境变量跳转执行 gotHome
set "CATALINA_HOME=%CURRENT_DIR%"          	 //如果没有设置,则设置 CATALINA_HOME 变量为:D:Code	omcat9in 
if exist "%CATALINA_HOME%incatalina.bat" goto okHome //查看"当前工作目录in" 目录(即D:Code	omcat9in)下是否存在catalina.bat 文件,如存在跳转okHome
cd ..					//回到上级子目录,即:D:Code	omcat9 ,此时当前工作目录已经更改为:D:Code	omcat9
set "CATALINA_HOME=%cd%" 		// 更改 CATALINA_HOME 变量值为:D:Code	omcat9in????
cd "%CURRENT_DIR%"			//切换至当前工作目录:D:Code	omcat9

最后,我用一句话来鼓励你我,这群在路上前进的人:“所有的伟大,源于一个勇敢的开始”。