在日常的開發中,經常要使用到tomcat,一般情況下,我們只需要下載zip版的tomcat,並在ide中進行配置即可。而不需要將tomcat註冊成服務,但在部署中,如果需要將tomcat部署到客戶機器上時,就會出現一定問題了。
一般情況下,如果要部署成服務的形式,就需要下載專門的windows安裝版(一個exe的安裝檔案),在windows下進行安裝。而這種安裝
版,有一個問題就是,它預設的服務名就是tomcat6或tomcat7,而不能手動的進行修改。如果需要安裝多個tomcat,就不能使用安裝版了。在
這種情況下,我們一般是下載zip版的tomcat,通過service.bat的方式來將tomcat註冊成服務。
一般情況下,註冊成服務的tomcat並不能啟動,問題有很多種。我就在實際過程中發現的問題,一一列舉出來,以方便碰到此問題的同學一起解決這個問題。
A service specific error occurred: 0.More help is available by typing NET HELPMSG 3547.
第一個問題:如果註冊服務都註冊不成功,則首先要檢查註冊服務所使用的命令能否檢測到所安裝的java。這個檢查只需要查看命令列是否出現以下字樣即可:
Installing the service 'Tomcat6' ...Using CATALINA_HOME: E:/javaServer/tomcat6utf8Using CATALINA_BASE: E:/javaServer/tomcat6utf8Using JAVA_HOME: C:/jdk1.6.0_24Using JVM: C:/jdk1.6.0_24/jre/bin/server/jvm.dllThe service 'Tomcat6' has been installed.
如果出現以下字樣,則表示已經檢測到了java。
第二個問題:網上經常說的msvcr71.dll和msvcp71.dll。這兩個dll檔案只需要放到windows的path環境變數可以找到的地方即可,並不需要特別的放到某一個特殊的地方。
查看這個檔案是否能夠被找到的一個很簡單的方法,即是在命令列輸入這兩個檔案,如:
E:/javaServer/tomcat6utf8/bin>msvcr71.dll
如果windows找到了這個檔案,則就會彈出一個如何開啟檔案的對話方塊,請求你如果開啟這個檔案。這就表示windows已經找到了這個檔案。
當然,如果把這兩個檔案都copy到tomcat的bin目錄下,也是一種解決方案(沒做過測試)
第三個問題:java版本和tomcat版本問題。
這裡說的版本問題並不簡單地是一個jre5和jre6的問題,一般來說,安裝tomcat6需要jre5,安裝tomcat7需要jre6,這都是常識的問題。
特殊的問題就是:你的tomcat版本需要和jvm的版本相一致。
我碰到這個問題,總是找不到解決問題的方法,最後發現,如果將安裝版裡的
tomcat.exe檔案copy至zip版的bin目錄,並覆蓋原tomcat.exe檔案,服務就能夠正常啟動,但它內建的zip版的
tomcat.exe死活不能啟動,查看了兩個exe的區別,除了大小不一樣,其它的配置都一樣。我注意到一個問題,就是官方對於安裝版的tomcat,
說明它可以試用於win32系統,也可以試用於64位系統,這就是問題的關鍵。
我機器上的java版本是64位的,而下載的zip版tomcat是32位的,在啟動tomcat時,會在logs目錄下的jakata-service.log檔案中出現以下內容:
[2011-03-31 12:00:45] [174 javajni.c] [error] %1 is not a valid Win32 application.[2011-03-31 12:00:45] [994 prunsrv.c] [error] Failed creating java C:/jdk1.6.0_24/jre/bin/server/jvm.dll[2011-03-31 12:00:45] [1269 prunsrv.c] [error] ServiceStart returned 1
表示不能啟動jvm。當我通過修改服務的註冊表,將其使用時使用的jvm換成32位的jvm時,服務就啟動了。這就表示,zip版的
tomcat需要根據jvm來下載不同的zip。在官方下載中,確實看到了zip版的tomcat有32位和64位之分,我下載64位的tomcat下
來,註冊成服務之後,tomcat直接啟動成功。看來確實是jvm適用系統版本和tomcat適用系統版本不一致的問題。
當然,在開發過程中,我們都是使用startup.bat來啟動tomcat,這裡面就沒有涉及到exe的問題,實際上就是調用java來啟動
tomcat,因此這個問題不會出現。其實32位tomcat和64tomcat的區別,就在於它提供的tomcat.exe的不同。