首先了解下JVM中幾個相關(guān)的概念:
Xms:最小堆大小
Xmx:最大堆大小
Xmn:年輕代堆大小
Xss:每個線程的堆大小
PermSize:初始持久代大小
MaxPermSize:最大持久代大小
一般Xms、Xmx設(shè)置相同,PermSize、MaxPermSize設(shè)置相同,這樣可以避免伸縮堆大小帶來的性能損耗。
首先eclipse安裝根目錄下打開eclipse.ini,加上配置:
-XX:+PrintGCTimeStamps
-XX:+PrintGCDetails
目的是運(yùn)行eclipse的時候可以打出詳細(xì)gc過程。
啟動eclipse,然后打開gc.log一看,哇塞啟動一次就做了幾十次GC,包括不少次Full GC,著手優(yōu)化……
先解決Full GC的問題:
3.159: [Full GC 3.159: [Tenured: 22716K->26133K(35780K), 0.1116536 secs] 38493K->26133K(51908K), [Perm : 20479K->20479K(20480K)], 0.1117614 secs] [Times: user=0.11 sys=0.00, real=0.11 secs]
3.706: [Full GC 3.706: [Tenured: 26133K->27935K(43556K), 0.1235449 secs] 40042K->27935K(63204K), [Perm : 24575K->24575K(24576K)], 0.1236474 secs] [Times: user=0.13 sys=0.00, real=0.13 secs]
……
如上GC日志可以看出,F(xiàn)ull GC主要是針對Tenured、Perm區(qū)的GC,好那先調(diào)整Perm大小,指定充裕的持久代區(qū)域,eclipse.ini中加入:
-XX:MaxPermSize=128m
再次啟動看gc.log,F(xiàn)ull GC沒有了,但是還有很多次普通GC,說明還是需要進(jìn)一步優(yōu)化。
eclipse的初始堆大小分配得很小,因此不利于年輕代堆大小的分配,如果設(shè)置的年輕代堆大小Xmn大于最小堆大小Xms,eclipse將無法啟動。
因此,將Xms調(diào)整為512m,重啟動后觀察GC大幅減少。
最后調(diào)整Xmn,年輕代堆大小,經(jīng)過反復(fù)比較后,發(fā)現(xiàn)設(shè)置“-Xmn256m”效果最優(yōu)。
優(yōu)化后的GC日志:
5.422: [GC 5.422: [DefNew: 235968K->12433K(235968K), 0.0989335 secs] 236976K->39296K(498112K), 0.0990229 secs]
在接近6秒的啟動時間內(nèi),eclipse總共只做了2次普通GC回收,怎么樣效果明顯吧!