隨筆-348  評論-598  文章-0  trackbacks-0
          今天還碰到了PermGen Space 的異常,搜索了一下有一些解決方法
          1

          PermGen space的全稱是Permanent Generation space,是指內存的永久保存區域OutOfMemoryError: PermGen space從表面上看就是內存益出,解決方法也一定是加大內存。說說為什么會內存益出:這一部分用于存放Class和Meta的信息,Class在被 Load的時候被放入PermGen space區域,它和和存放Instance的Heap區域不同,GC(Garbage Collection)不會在主程序運行期對PermGen space進行清理,所以如果你的APP會LOAD很多CLASS的話,就很可能出現PermGen space錯誤。這種錯誤常見在web服務器對JSP進行pre compile的時候。

          改正方法:
          -Xms256m -Xmx256m -XX:MaxNewSize=256m -XX:MaxPermSize=256m 
          2

          在tomcat中redeploy時出現outofmemory的錯誤.

          可以有以下幾個方面的原因:

          ,使用了proxool,因為proxool內部包含了一個老版本的cglib.

          2, log4j,最好不用,只用common-logging

          3, 老版本的cglib,快點更新到最新版。

          ,更新到最新的hibernate3.2

          3

          這里以tomcat環境為例,其它WEB服務器如jboss,weblogic等是同一個道理。 
          一、java.lang.OutOfMemoryError: PermGen space 
          PermGen space的全稱是Permanent Generation space,是指內存的永久保存區域, 
          這塊內存主要是被JVM存放Class和Meta信息的,Class在被Loader時就會被放到PermGen space中, 
          它和存放類實例(Instance)的Heap區域不同,GC(Garbage Collection)不會在主程序運行期對 
          PermGen space進行清理,所以如果你的應用中有很多CLASS的話,就很可能出現PermGen space錯誤, 
          這種錯誤常見在web服務器對JSP進行pre compile的時候。如果你的WEB APP下都用了大量的第三方jar, 其大小 
          超過了jvm默認的大小(4M)那么就會產生此錯誤信息了。 
          解決方法: 手動設置MaxPermSize大小

          修改TOMCAT_HOME
          /bin/catalina.sh 
          在“echo 
          "Using CATALINA_BASE: $CATALINA_BASE"”上面加入以下行: 
          JAVA_OPTS
          ="-server -XX:PermSize=64M -XX:MaxPermSize=128m 
          建議:將相同的第三方jar文件移置到tomcat/shared/lib目錄下,這樣可以達到減少jar 文檔重復占用內存的目的。

          二、java.lang.OutOfMemoryError: Java heap space 
          Heap size 設置 
          JVM堆的設置是指java程序運行過程中JVM可以調配使用的內存空間的設置.JVM在啟動的時候會自動設置Heap size的值, 
          其初始空間(即
          -Xms)是物理內存的1/64,最大空間(-Xmx)是物理內存的1/4。可以利用JVM提供的-Xmn -Xms -Xmx等選項可 
          進行設置。Heap size 的大小是Young Generation 和Tenured Generaion 之和。 
          提示:在JVM中如果98%的時間是用于GC且可用的Heap size 不足2%的時候將拋出此異常信息。 
          提示:Heap Size 最大不要超過可用物理內存的80%,一般的要將
          -Xms和-Xmx選項設置為相同,而-Xmn為1/4的-Xmx值。 
          解決方法:手動設置Heap size 
          修改TOMCAT_HOME
          /bin/catalina.sh 
          在“echo 
          "Using CATALINA_BASE: $CATALINA_BASE"”上面加入以下行: 
          JAVA_OPTS
          ="-server -Xms800m -Xmx800m -XX:MaxNewSize=256m"

          三、實例,以下給出1G內存環境下java jvm 的參數設置參考:

          JAVA_OPTS
          ="-server -Xms800m -Xmx800m -XX:PermSize=64M -XX:MaxNewSize=256m -XX:MaxPermSize=128m -Djava.awt.headless=true "

          三、相關資料

          http:
          //www.tot.name/show/3/7/20061112220131.htm

          http:
          //www.tot.name/show/3/7/20061112220054.htm

          http:
          //www.tot.name/show/3/7/20061112220201.htm

          題外話:經常看到網友抱怨tomcat的性能不如,不穩定等,其實根據筆者幾年的經驗,從
          "互聯星空“到現在的房產門戶網,我們 
          均使用tomcat作為WEB服務器,每天訪問量百萬多,tomcat仍然運行良好。建議大家有問題多從自己程序入手,多看看java的DOC文檔 
          并詳細了解JVM的知識。這樣開發的程序才會健壯。

          JVM 性能調整的一些基本概念 
          http:
          //www.wujianrong.com/archives/2007/02/jvm_1.html#more 
          apache+Tomcat負載平衡設置詳解

          http:
          //www.wujianrong.com/archives/2006/11/apachetomcat.html 
          java - the Java application launcher

          http:
          //java.sun.com/j2se/1.3/docs/tooldocs/linux/java.html

          JVM調優 
          http:
          //www.wujianrong.com/archives/2006/11/jvm.html

          但是我還搜索到JavaEye的這篇文章http://www.javaeye.com/topic/80620
          他提到了這個不是開源框架的問題,是Sun JDK的問題,屬于Bug,但是至今還沒有修正。
          我也感覺是這樣的,因為我的應用很小,基本不可能將內存耗盡,而且tomcat或者JBoss運行半個小時就會崩潰,我以前沒有太碰到過,今天算是領教了,解決辦法除了上面的,還可以換一個JDK,可以使用BEA的JRockit


          ---------------------------------------------------------
          專注移動開發

          Android, Windows Mobile, iPhone, J2ME, BlackBerry, Symbian
          posted on 2007-10-14 17:06 TiGERTiAN 閱讀(14868) 評論(3)  編輯  收藏 所屬分類: Java

          評論:
          # re: java.lang.OutOfMemoryError: PermGen space 的疑惑 2007-10-17 08:52 | dennis
          PermGen space也就是sun JVM的方法區,固定一個地方,如果你的應用應用了很多反射技術(比如spring、hibernate),這個區默認的大小一般是不夠的。對于ibm和bea的JDK,方法區不是固定的,可以增加或者縮小,因此沒有這個問題,不過你可能會遇到堆碎片引起的OOM  回復  更多評論
            
          # re: java.lang.OutOfMemoryError: PermGen space 的疑惑 2007-10-17 10:55 | TiGERTiAN
          恩,的確,但是我以前好像沒有遇到過這種問題哈,實際開發部署中一般怎么解決這種問題啊?  回復  更多評論
            
          # re: java.lang.OutOfMemoryError: PermGen space 的疑惑 2009-07-19 00:08 | oil painting
          恩,的確.....  回復  更多評論
            
          主站蜘蛛池模板: 莱芜市| 道孚县| 南康市| 安顺市| 关岭| 什邡市| 双流县| 绍兴市| 东乡族自治县| 华蓥市| 荃湾区| 含山县| 上饶县| 河曲县| 罗田县| 长顺县| 福鼎市| 绥芬河市| 桐梓县| 武平县| 黄浦区| 阿拉尔市| 墨玉县| 筠连县| 蒙城县| 高台县| 白山市| 华宁县| 庆安县| 岗巴县| 泰兴市| 八宿县| 锡林郭勒盟| 甘孜| 宝山区| 九江县| 林州市| 株洲县| 玉树县| 彰化市| 嘉峪关市|