tomcat常見錯誤及解決方案
不管是初學者還是有經驗的web程序員,使用Tomcat容器的時候會發生包括404,運行啟動錯誤,以及亂碼等等的問題,現在我將開發過程中遇到的常見錯誤和簡單解決方法貼出來供大家看看,里面有部分是同事總結,我們共同完成的這篇文章。。。
一,tomcat啟動時錯誤
1:The JAVA_HOME environment variable is not defined This environment variable is needed to run this program;
Re:沒有在在tomcat的配置文件.bash_profile中設置環境變量JAVA_HOME,具體設置方法為:加入如下幾行:
JAVA_HOME=/home/tomcat/j2sdk1.4.2_08(具體值要以實際的jdk安裝路徑為准)
export JAVA_HOMECLASSPATH=/home/tomcat/j2sdk1.4.2_08/lib/tools.jar:/home/tomcat/j2sdk1.4.2_08/lib/dt.jar
export CLASSPATH
2。 Error occurred during initialization of VM Could not reserve enough space for object heap
Re:在tomcat的bin目錄下,catalina.sh文件的tomcat內存參數配置過大,超過機器可用內存總數造成,修改到適當的值即可,修改的參數為:JAVA_OPTS="-Xms50m -Xmx60m"
3 . tomcat啟動時報某個目錄沒有權限,啟動失敗,或者不能執行某些jsp頁
Re:tomcat需要tomcat用戶具有一些目錄和文件的相應權限, 所有目錄應該具有讀寫執行(瀏覽)的權限,jsp,class文件應該最少具有讀權限, 一些文件需要寫權限,下面是已知的需要讀寫權限文件的列表:
$CATALINA_HOME/logs下所有文件
$CATALINA_HOME/work下所有文件
$CATALINA_HOME/publish/main/count.txt文件
$CATALINA_HOME/publish/chatroom/resource下的所有.xml文件
所有上傳圖片目錄都需要寫權限。
改變文件目錄權限的方法:執行下面命令,設置所有的tomcat安裝下的文件和目錄,可以保證執行,但是不是很安全。
1. 設置tomcat上級目錄/opt所有用戶都有讀寫執行權限:
chmod 777 [tomcat的上級目錄]
2. 設置tomcat5.0.28目錄下的所有文件的屬主為tomcat:
chown -R tomcat [tomcat安裝目錄]
3. 設置所有tomcat5.0.28下的所有文件和目錄的屬主(tomcat)具有讀寫執行權限
chmod 700 -R /opt/tomcat5.0.28
4. 執行startup.sh文件后告訴地址已經使用,導致tomcat不能啟動
Re:可能是前一次執行./shutdown.sh文件關閉tomcat時沒有停止已經啟動的java進程,而這個進程仍然在監聽tomcat所使用的端口,或者有另外一個tomcat正在運行,server.xml文件中的監聽端口和當前tomcat沖突。
使用下面命令查看當前系統是否有正在監聽的端口(8080--webcache, 90--www或http).
1. 列出所有系統正在監聽的端口和綁定的地址netstat -l
2. 找出當前系統中的所有進程,管道符號過濾輸出顯示包含java字符串的行
ps -A |grep java
tty time proc
1021 ? java
3. 結束一個指定的進程:
kill [進程號]
4. 強制殺死一個進程:
kill -9 [進程號]
如果確定不是別的tomcat運行導致的沖突或者沒有java進程運行可以再次運行startup.sh文件啟動tomcat
二 Tomcat 運行時錯誤及解決
1. org.apache.commons.dbcp.SQLNestedException: Cannot create PoolableConnectionFactory (Network error IOException: Connection refused: connect)
2. Caused by: java.sql.SQLException: Network error IOException: Connection refused: connect
3. Caused by: java.net.ConnectException: Connection refused: connect
Re:數據庫未開情況下運行tomcat出現的問題,把數據庫打開就行了
4.java.lang.NoSuchMethodError: org.objectweb.asm.ClassVisitor.visit(IILjava/lang/String;Ljava/lang/String;[Ljava/lang/String;Ljava/lang/String;)V
at net.sf.cglib.core.ClassEmitter.begin_class(ClassEmitter.java:77) 這個問題是最最常見的,第一次整合ssh的時候會發現這個問題,有時候刪除掉相關的包還是會沖突。所以解決辦法我一般是:
Re:把MyEclipse中的Hibernate中的有關ASM的包全部刪除,將spring中asm包拷貝進去重啟就Ok了,有時候需要刪除其他文件,到網上找找吧;
還有個解決辦法:Spring 和 Hibernate 共用的一些 jar 文件發生了版本沖突, 刪除 WEB-INF/lib/asm-2.2.3.jar 然后重啟 Tomcat.
5 .javax.servlet.jsp.JspException: Invalid argument looking up property usersVO.account of bean loginForm
Re,一般提示這種錯誤表示VO中的form沒有實例化,在reset方法中new一下就Ok了。養成良好的編碼習慣可以避免這種簡單錯誤。
6.嚴重: Exception loading sessions from persistent storage
Re:tomcat安裝目錄\work\Catalina\localhost\{webAppName}\SESSIONS.ser,刪除此文件
三 .數字提示錯誤
- 出現404錯誤是因為你所請求的頁面不可用!這是response對象的http響應中的狀態行404表示當前請求的頁面不可用!
- 200表示測試通過。
- 500表示服務器內部發生錯誤等!