不論是在開(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