天天看點

tomcat啟動一閃而逝



遇到很多次運作startup.bat後,一個視窗一閃而過的問題,但是從來沒去糾正怎樣修改配置才是正确的,現在從網上查閱的資料整理如下:

是不是已經tomcat已經啟動過了,你可以shutdown.bat幾次,重新啟動試一下

tomcat在啟動時,會讀取環境變量的資訊,需要一個CATALINA_HOME 與JAVA_HOME的資訊,CATALINA_HOME即tomcat的主目錄,JAVA_HOME即java安裝的主目錄,jdk的主目錄。

首先,要在環境變量處,配置JAVA_HOME,注意變量值是jdk的主目錄,不是bin目錄,并且不要加分号,如圖:

tomcat啟動一閃而逝

然後,如果這樣配置,

startup.bat還是一閃而過,可以右鍵點選

startup.bat,編輯,在文本的最後敲上pause,儲存後重新運作startup.bat,這時候視窗不會再一閃而過,而是停留在桌面上(調試成功,把pause去掉即可)。

tomcat啟動一閃而逝

如果有錯誤資訊,這時候會顯示出來,可以再根據它的錯誤提示,上網搜尋對應的解決辦法,下面是在錯誤提示視窗遇到過的問題:

一、 Neither the JAVA_HOME nor the JRE_HOME environment variable is defined

Tomcat的startup.bat,它調用了catalina.bat,而catalina.bat則調用了setclasspath.bat,隻要在setclasspath.bat的開頭聲明環境變量(紅色兩行)就可以了,原因是後來較新版本安裝完不會自動登記環境變量JAVA_HOME,JRE_HOME。

給setclasspath.bat的開頭添加紅色标記部分,如下:

rem ---------------------------------------------------------------------------

rem Set CLASSPATH and Java options

rem

rem $Id: setclasspath.bat 505241 2007-02-09 10:22:58Z jfclere $

rem ---------------------------------------------------------------------------

set JAVA_HOME=C:\Program Files\Java\jdk1.6.0_20

set JRE_HOME=C:\Program Files\Java\jre6

rem Make sure prerequisite environment variables are set

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

這樣在每次運作startup.bat時就自動注冊了JAVA_HOME,JRE_HOME。

運作startup.bat,提示“資訊:Server startup in xxxxx ms”  OK 大功告成。

二、Cannot find ""d:\apache-tomcat-6.0.32"\bin\setclasspath.bat"

這個時候,可能是CATALINA_HOME的值在某個地方被寫死了,像我的綠色版tomcat在bin檔案下多了一個setenv.bat的檔案,打開一看果然是在這裡面被寫死了

CATALINA_HOME的路徑,這應該是為了某種原因被人後加上的設定檔案,把這個檔案删除之後,tomcat可以正常運作了。

tomcat啟動一閃而逝

這種情況,可以去看catalina.bat中的配置,如下圖,可能配置死的内容就在這個檔案裡。

tomcat啟動一閃而逝

轉自:http://blog.csdn.net/znn626/article/details/7893555