JVM垃圾回收機(jī)制簡(jiǎn)介
這里向大家描述一下JVM垃圾回收機(jī)制的概念,JVM垃圾回收分多級(jí),1級(jí)或以上為部分JVM垃圾回收,只會(huì)回收Young中的垃圾,內(nèi)存溢出通常發(fā)生于OLD段或Perm段JVM垃圾回收后,仍然無(wú)內(nèi)存空間容納新的Java對(duì)象的情況。
JVM垃圾回收簡(jiǎn)介:
JVM垃圾回收分多級(jí),0級(jí)為全部(Full)的JVM垃圾回收,會(huì)回收OLD段中的垃圾;1級(jí)或以上為部分JVM垃圾回收,只會(huì)回收Young中的垃圾,內(nèi)存溢出通常發(fā)生于OLD段或Perm段JVM垃圾回收后,仍然無(wú)內(nèi)存空間容納新的Java對(duì)象的情況。
當(dāng)一個(gè)URL被訪問(wèn)時(shí),內(nèi)存申請(qǐng)過(guò)程如下:
A.JVM會(huì)試圖為相關(guān)Java對(duì)象在Eden中初始化一塊內(nèi)存區(qū)域
B.當(dāng)Eden空間足夠時(shí),內(nèi)存申請(qǐng)結(jié)束。否則到下一步
C.JVM試圖釋放在Eden中所有不活躍的對(duì)象(這屬于1或更高級(jí)的JVM垃圾回收);釋放后若Eden空間仍然不足以放入新對(duì)象,則試圖將部分
Eden中活躍對(duì)象放入Survivor區(qū)/OLD區(qū)
D.Survivor區(qū)被用來(lái)作為Eden及OLD的中間交換區(qū)域,當(dāng)OLD區(qū)空間足夠時(shí),Survivor區(qū)的對(duì)象會(huì)被移到Old區(qū),否則會(huì)被保留在Survivor區(qū)
E.當(dāng)OLD區(qū)空間不夠時(shí),JVM會(huì)在OLD區(qū)進(jìn)行完全的垃圾收集(0級(jí))
F.完全垃圾收集后,若Survivor及OLD區(qū)仍然無(wú)法存放從Eden復(fù)制過(guò)來(lái)的部分對(duì)象,導(dǎo)致JVM無(wú)法在Eden區(qū)為新對(duì)象創(chuàng)建內(nèi)存區(qū)域,則出現(xiàn)"outofmemory錯(cuò)誤"。下面看一下JVM垃圾回收機(jī)制的Java堆的相關(guān)參數(shù)。
Java堆相關(guān)參數(shù):
ms/mx:定義YOUNG+OLD段的總尺寸,ms為JVM啟動(dòng)時(shí)YOUNG+OLD的內(nèi)存大??;mx為最大可占用的YOUNG+OLD內(nèi)存大小。在用戶生產(chǎn)環(huán)境上一般將這兩個(gè)值設(shè)為相同,以減少運(yùn)行期間系統(tǒng)在內(nèi)存申請(qǐng)上所花的開(kāi)銷(xiāo)。
NewSize/MaxNewSize:定義YOUNG段的尺寸,NewSize為JVM啟動(dòng)時(shí)YOUNG的內(nèi)存大小;MaxNewSize為最大可占用的YOUNG內(nèi)存大小。在用戶生產(chǎn)環(huán)境上一般將這兩個(gè)值設(shè)為相同,以減少運(yùn)行期間系統(tǒng)在內(nèi)存申請(qǐng)上所花的開(kāi)銷(xiāo)。
PermSize/MaxPermSize:定義Perm段的尺寸,PermSize為JVM啟動(dòng)時(shí)Perm的內(nèi)存大?。籑axPermSize為最大可占用的Perm內(nèi)存大小。在用戶生產(chǎn)環(huán)境上一般將這兩個(gè)值設(shè)為相同,以減少運(yùn)行期間系統(tǒng)在內(nèi)存申請(qǐng)上所花的開(kāi)銷(xiāo)。
SurvivorRatio:設(shè)置Survivor空間和Eden空間的比例
例:
- MEM_ARGS="-Xms512m-Xmx512m
- -XX:NewSize=256m-XX:MaxNewSize=256m
- -XX:PermSize=128m-XX:MaxPermSize=128m
- -XX:SurvivorRatio=6"
在上面的例子中:
- YOUNG+OLD:512M
- YOUNG:256M
- Perm:128M
- Eden:YOUNG*6/(6+1+1)=192M
- Survivor:YOUNG/(6+1+1)=32M
Java堆的總尺寸=YOUNG+OLD+Perm=640M
【編輯推薦】