启动tomcat时cmd窗口一闪而过解决方法

启动tomcat时cmd窗口一闪而过解决方法。

问题现象:

在实际开发中一般都是eclipse+tomcat(也许还会用到tomcat的插件),我们只需要在eclipse中单击servers上的按钮就可以成功启动tomcat了,

但是如果想在tomcat的安装目录下 双击startup.bat启动时却一闪而过了。这是为什么呢(tomcat启动失败),马上就带大家看看具体的原因。

下面我先跟大家确认一下问题出现的前提条件(本机版本java:1.6.20,tomcat:6.0.32):

1)在eclipse里面启动tomcat时都是正常的。

2)在系统中配置了各种环境变量如下:

JAVA_HOME:H:\DevelopTools\Java\jdk1.6.0_20

CATALINA_BASE:H:\DevelopTools\apache-tomcat-6.0.32

CATALINA_HOME:H:\DevelopTools\apache-tomcat-6.0.32

CLASSPATH:.;%JAVA_HOME%;%JAVA_HOME%\jre\lib;

PATH:.;%JAVA_HOME%\bin;%CATALINA_HOME%\bin;

来分析一下:

进入tomcat的安装目录(即解压后放置的地方):

看到圈出红色的3个bat文件,一般通过startup.bat启动tomcat时流程是:startup->catalina->setclasspath->catalina

如果这3个bat文件里面有一个出现错误的话就是启动失败。为了找到一闪而过的原因得需要我们来看看这3个文件里面到底是什么了

启动tomcat时cmd窗口一闪而过解决方法_第1张图片

先记事本打开startup.bat,找到最后一句话::end,我们知道end表示结束的意思,:end是一个标记,我们在后面加上一句pause

启动tomcat时cmd窗口一闪而过解决方法_第2张图片

启动tomcat时cmd窗口一闪而过解决方法_第3张图片

(暂停等待的意思)再次执行startup.bat,就会看到上图,当我们按任意的键时cmd窗口又是一闪而过了。但是这已经确定了我们的环境变量都是正确的。

 

 

为了更加详细的看到信息,我们再来更改一句:找到call "%EXECUTABLE%" start %CMD_LINE_ARGS% 把里面的start替换为run。

启动tomcat时cmd窗口一闪而过解决方法_第4张图片

启动tomcat时cmd窗口一闪而过解决方法_第5张图片

再来看看cmd窗口里面输出错误信息了:

error occurred during initialization of vm

could not reserve enough space for objectheap

could not create the java virtual machine

我们大体可以理解为:因为程序请求不到足够的内存就启动不了vm,导致程序退出。

那么我们可以来解决这个问题了:申请足够的内存就可以了

如下操作:在catalina.bat中 找到Execute The Requested Command下面的

set JAVA_OPTS把这一句替换为:

set JAVA_OPTS=%JAVA_OPTS% -server -Xms800m-Xmx800m -XX:MaxNewSize=256m

再次启动startup.bat会看到

已经启动成功了(记得把之前修改的内容run、pause还原回去)。

到这里,貌似问题已经解决了,如果遇到其他的问题该怎么解决呢(因为其他的问题也会导致cmd窗口一闪而过)?

  1. tomcat/bin/setclasspath.bat 用记事本打开

  2. 添加添加两行代码java根目录和Jre根目录

    set JAVA_HOME=E:\Program Files\Java\jdk1.7.0_13

    set JRE_HOME=E:\Program Files\Java\jdk1.7.0_13\jre

  3. 查看到错误JRE_HOME environment variable is not defined correctly……网上好多解决办法,我用了都不好用,还有一些也麻烦,我就说一简单的,也是找了好久发现的,startup.bat里边实际调用了另一个批处理,就是setclasspath.bat这个文件,把这个文件以文本形式打开,里边其实写的就是寻找你配置的JAVA_HOME和JRE_HOME路径,既然电脑傻了吧唧的找不到,那咱就不让他找了,咱就直接给他就完了呗。以下为编辑位置rem ---------------------------------------------------------------------------rem Set JAVA_HOME or JRE_HOME if not already set, ensure any provided settingsrem are valid and consistent with the selected start-up options and set up therem endorsed directory.remrem $Id: setclasspath.bat 1202062 2011-11-15 06:50:02Z mturk $rem ---------------------------------------------------------------------------rem --------进入编辑begin--------下边两行是自己写的---------------------set JAVA_HOME=C:\glassfish3\jdk7set JRE_HOME=C:\Program Files\Java\jre7rem --------进行编辑end---------上边两行诗自己写的----------------------rem Make sure prerequisite environment variables are setrem In debug mode we need a real JDK (JAVA_HOME)


你可能感兴趣的:(Java)