JVM垃圾回收機制簡介
這里向大家描述一下JVM垃圾回收機制的概念,JVM垃圾回收分多級,1級或以上為部分JVM垃圾回收,只會回收Young中的垃圾,內存溢出通常發生于OLD段或Perm段JVM垃圾回收后,仍然無內存空間容納新的Java對象的情況。
JVM垃圾回收簡介:
JVM垃圾回收分多級,0級為全部(Full)的JVM垃圾回收,會回收OLD段中的垃圾;1級或以上為部分JVM垃圾回收,只會回收Young中的垃圾,內存溢出通常發生于OLD段或Perm段JVM垃圾回收后,仍然無內存空間容納新的Java對象的情況。
當一個URL被訪問時,內存申請過程如下:
A.JVM會試圖為相關Java對象在Eden中初始化一塊內存區域
B.當Eden空間足夠時,內存申請結束。否則到下一步
C.JVM試圖釋放在Eden中所有不活躍的對象(這屬于1或更高級的JVM垃圾回收);釋放后若Eden空間仍然不足以放入新對象,則試圖將部分
Eden中活躍對象放入Survivor區/OLD區
D.Survivor區被用來作為Eden及OLD的中間交換區域,當OLD區空間足夠時,Survivor區的對象會被移到Old區,否則會被保留在Survivor區
E.當OLD區空間不夠時,JVM會在OLD區進行完全的垃圾收集(0級)
F.完全垃圾收集后,若Survivor及OLD區仍然無法存放從Eden復制過來的部分對象,導致JVM無法在Eden區為新對象創建內存區域,則出現"outofmemory錯誤"。下面看一下JVM垃圾回收機制的Java堆的相關參數。
Java堆相關參數:
ms/mx:定義YOUNG+OLD段的總尺寸,ms為JVM啟動時YOUNG+OLD的內存大??;mx為最大可占用的YOUNG+OLD內存大小。在用戶生產環境上一般將這兩個值設為相同,以減少運行期間系統在內存申請上所花的開銷。
NewSize/MaxNewSize:定義YOUNG段的尺寸,NewSize為JVM啟動時YOUNG的內存大?。籑axNewSize為最大可占用的YOUNG內存大小。在用戶生產環境上一般將這兩個值設為相同,以減少運行期間系統在內存申請上所花的開銷。
PermSize/MaxPermSize:定義Perm段的尺寸,PermSize為JVM啟動時Perm的內存大??;MaxPermSize為最大可占用的Perm內存大小。在用戶生產環境上一般將這兩個值設為相同,以減少運行期間系統在內存申請上所花的開銷。
SurvivorRatio:設置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
【編輯推薦】