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

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

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

          在tomcat中redeploy時出現(xiàn)outofmemory的錯誤.

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

          ,使用了proxool,因為proxool內(nèi)部包含了一個老版本的cglib.

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

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

          ,更新到最新的hibernate3.2

          3

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

          二、java.lang.OutOfMemoryError: Java heap space 
          Heap size 設置 
          JVM堆的設置是指java程序運行過程中JVM可以調(diào)配使用的內(nèi)存空間的設置.JVM在啟動的時候會自動設置Heap size的值, 
          其初始空間(即
          -Xms)是物理內(nèi)存的1/64,最大空間(-Xmx)是物理內(nèi)存的1/4。可以利用JVM提供的-Xmn -Xms -Xmx等選項可 
          進行設置。Heap size 的大小是Young Generation 和Tenured Generaion 之和。 
          提示:在JVM中如果98%的時間是用于GC且可用的Heap size 不足2%的時候?qū)伋龃水惓P畔ⅰ?nbsp;
          提示:Heap Size 最大不要超過可用物理內(nèi)存的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內(nèi)存環(huán)境下java jvm 的參數(shù)設置參考:

          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

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

          JVM 性能調(diào)整的一些基本概念 
          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調(diào)優(yōu) 
          http:
          //www.wujianrong.com/archives/2006/11/jvm.html

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


          ---------------------------------------------------------
          專注移動開發(fā)

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

          評論:
          # re: java.lang.OutOfMemoryError: PermGen space 的疑惑 2007-10-17 08:52 | dennis
          PermGen space也就是sun JVM的方法區(qū),固定一個地方,如果你的應用應用了很多反射技術(比如spring、hibernate),這個區(qū)默認的大小一般是不夠的。對于ibm和bea的JDK,方法區(qū)不是固定的,可以增加或者縮小,因此沒有這個問題,不過你可能會遇到堆碎片引起的OOM  回復  更多評論
            
          # re: java.lang.OutOfMemoryError: PermGen space 的疑惑 2007-10-17 10:55 | TiGERTiAN
          恩,的確,但是我以前好像沒有遇到過這種問題哈,實際開發(fā)部署中一般怎么解決這種問題啊?  回復  更多評論
            
          # re: java.lang.OutOfMemoryError: PermGen space 的疑惑 2009-07-19 00:08 | oil painting
          恩,的確.....  回復  更多評論
            
          主站蜘蛛池模板: 富蕴县| 怀远县| 武穴市| 康定县| 策勒县| 平凉市| 舞钢市| 荥经县| 江北区| 修文县| 洛隆县| 称多县| 清远市| 绥德县| 汾阳市| 诏安县| 兴国县| 黄石市| 井冈山市| 甘孜| 华安县| 卢龙县| 澎湖县| 黑水县| 南澳县| 广河县| 名山县| 黄山市| 铜山县| 延川县| 新乡县| 连江县| 五原县| 湘阴县| 包头市| 年辖:市辖区| 中方县| 青海省| 景洪市| 彰武县| 新建县|