vickzhu

            BlogJava :: 首頁(yè) :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
            151 隨筆 :: 0 文章 :: 34 評(píng)論 :: 0 Trackbacks
          <2008年9月>
          31123456
          78910111213
          14151617181920
          21222324252627
          2829301234
          567891011

          常用鏈接

          留言簿(6)

          隨筆檔案

          搜索

          最新評(píng)論

          閱讀排行榜

          評(píng)論排行榜

          不論是在開(kāi)發(fā)還是在已經(jīng)發(fā)布的項(xiàng)目中,我們經(jīng)常會(huì)碰到的一個(gè)問(wèn)題:
              java.lang.OutOfMemoryError: PermGen space

          PermGen space的全稱是Permanent Generation space,是指內(nèi)存的永久保存區(qū)域,OutOfMemoryError: PermGen space從表面上看就是內(nèi)存溢出,解決方法是加大內(nèi)存。說(shuō)說(shuō)為什么會(huì)內(nèi)存溢出:PermGen space用于存放Class和Meta的信息,Class在被 Load的時(shí)候被放入PermGen space區(qū)域,它和存放Instance的Heap區(qū)域不同,GC(Garbage Collection)不會(huì)在主程序運(yùn)行期對(duì)PermGen space進(jìn)行清理,所以如果你的APPLICATION會(huì)LOAD很多CLASS的話,就很可能出現(xiàn)PermGen space錯(cuò)誤。這種錯(cuò)誤常見(jiàn)在web服務(wù)器對(duì)JSP進(jìn)行pre compile的時(shí)候。如果你的WEB APP下都用了大量的第三方j(luò)ar, 其大小超過(guò)了jvm默認(rèn)的大小(4M)那么就會(huì)產(chǎn)生此錯(cuò)誤信息了。

          建議:將相同的第三方j(luò)ar文件移置到tomcat/lib目錄下,這樣可以達(dá)到減少jar 文檔重復(fù)占用內(nèi)存的目的。
          改正方法:-Xms256m -Xmx256m -XX:MaxNewSize=256m -XX:MaxPermSize=256m

          其中-Xms<size> 為JVM初始化堆的大小
                  -Xmx<size> 為JVM堆的最大值
                  -XX:MaxNewSize 為調(diào)大新對(duì)象區(qū),以減少垃圾回收器回收次數(shù)

          但是有的時(shí)候可能這樣的設(shè)置還會(huì)不行(比如,當(dāng)Server應(yīng)用程序加載較多類(lèi)時(shí),即jvm加載類(lèi)時(shí),永久域中的對(duì)象急劇增加,從而使jvm不斷調(diào)整永久域大小,為了避免調(diào)整),你可以使用更多的參數(shù)配置,如: java -Xms512m -Xmx512m -XX:PermSize=64m -XX:MaxPermSize=128m
          其中,使用   -XX:MaxPermSize標(biāo)志來(lái)增加永久域的大小,-XX:PermSize標(biāo)志設(shè)置初始值
          如果虛擬機(jī)啟動(dòng)時(shí)設(shè)置使用的內(nèi)存比較小而在這種情況下有許多對(duì)象進(jìn)行初始化,虛擬機(jī)就必須重復(fù)地增加內(nèi)存來(lái)滿足使用。由于這種原因,我們一般把-Xms和-Xmx設(shè)為一樣大,而堆的最大值受限于系統(tǒng)使用的物理內(nèi)存。一般使用數(shù)據(jù)量較大的應(yīng)用程序會(huì)使用持久對(duì)象,內(nèi)存使用有可能迅速地增長(zhǎng)。當(dāng)應(yīng)用程序需要的內(nèi)存超出堆的最大值時(shí)虛擬機(jī)就會(huì)提示內(nèi)存溢出,并且導(dǎo)致應(yīng)用服務(wù)崩潰。因此一般建議堆的最大值設(shè)置為可用內(nèi)存的最大值的80%。


          在tomcat中redeploy時(shí)出現(xiàn)outofmemory的錯(cuò)誤.
          可以有以下幾個(gè)方面的原因:
          1,使用了proxool,因?yàn)閜roxool內(nèi)部包含了一個(gè)老版本的cglib.
          2, log4j,最好不用,只用common-logging
          3, 老版本的cglib,快點(diǎn)更新到最新版。
          4,更新到最新的hibernate3.2

          posted on 2008-09-22 17:10 筱 筱 閱讀(7094) 評(píng)論(0)  編輯  收藏

          只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。


          網(wǎng)站導(dǎo)航:
           
          主站蜘蛛池模板: 天门市| 黎川县| 涿鹿县| 斗六市| 治多县| 砀山县| 都匀市| 本溪| 洛宁县| 清丰县| 高密市| 寿光市| 松江区| 苏尼特左旗| 北安市| 瓦房店市| 长宁县| 建瓯市| 苍山县| 宁城县| 安康市| 大竹县| 原阳县| 襄垣县| 芒康县| 新安县| 恭城| 雅安市| 唐海县| 德阳市| 长白| 苏尼特左旗| 定结县| 哈尔滨市| 南雄市| 巧家县| 兴仁县| 宜宾市| 达孜县| 璧山县| 荣昌县|