1. 程式人生 > >tomcat啟動時一閃而過的幾種原因

tomcat啟動時一閃而過的幾種原因

雙擊tomcat的bin目錄下的startup.bat時一閃而過時,可以右鍵startup.bat找一個文字編輯器開啟,然後在文字的最後敲上pause,儲存後重新執行startup.bat,這時候視窗會留在桌面上(除錯成功,把pause去掉即可)。我們可以看到DOS窗口裡有錯誤資訊。

1. The JRE_HOME environment variable is not defined correctly This environment variableis needed to run this program
原因:以前版本的tomcat需要JDK,現在的tomcat(本人的是7.0)只要有JRE就可以。 如果你裝的tomcat的是解壓版的(免安裝的)那麼則需要自己手動配置JRE_HOME 這個環境變數,否則,就會出現上面的錯誤。
解決辦法:右擊 我的電腦 - 高階 - 環境變數, 在系統變數中 新建
變數名:JRE_HOME
變數值:C:\Program Files\Java\jre7(根據你自己的JDK安裝目錄尋找JRE)

2.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 I

d:setclasspath.bat5052412007020910:22:58Zjfclere
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 大功告成。

3. Cannot find “”d:\apache-tomcat-6.0.32”\bin\setclasspath.bat”
這個時候,可能是CATALINA_HOME的值在某個地方被寫死了,像我的綠色版tomcat在bin檔案下多了一個setenv.bat的檔案,開啟一看果然是在這裡面被寫死了CATALINA_HOME的路徑,這應該是為了某種原因被人後加上的設定檔案,把這個檔案刪除之後,tomcat可以正常運行了。
這裡寫圖片描述
這種情況,可以去看catalina.bat中的配置,如下圖,可能配置死的內容就在這個檔案裡。
這裡寫圖片描述