原文地址:http://www.javaeye.com/topic/756538java
性能優化從身邊作起。
首先創建評估體系,將workspace裏全部的項目close掉,關閉eclipse。優化的用例就是啓動eclipse,open一個項目,eclipse會自動build這個項目,保證沒有感受到明顯的卡,也就是沒有full GC。
開始:
eclipse.ini里加入打印gc狀況的參數:
性能優化
-XX:+PrintGCTimeStamps |
-XX:+PrintGCDetails |
-verbose:gc |
-Xloggc:gc.log |
這樣eclipse在運行過程當中會記錄gc日誌,顯示詳細的gc狀況,並打印在gc.log中,經過分析這個日誌尋找eclipse的性能瓶頸和優化方式。
我最初的參數只是在原版基礎上調了堆大小eclipse
-Xms512m |
-Xmx512m |
將堆初始化和最大值設爲同樣,消除堆大小根據當前堆使用狀況而變化帶來的影響。
啓動eclipse,發現gc.log裏打出了不少full gc的日誌jvm
在啓動的6秒多時間裏共出現了8次full gc,因此啓動慢,以爲啓動時候挺卡的。從日誌裏能夠看出來 FullGC主要是在回收tenured區和Perm區,其中Perm一直都是快滿的狀態,Perm : 24574K->24554K(24576K),Perm大小在不斷調整,因此須要固定Perm區的大小,保證夠用,eclipse.ini里加入性能
-XX:PermSize=64m |
-XX:MaxPermSize=64m |
再啓動:發現沒有full gc了只有數量比較多的minor gc,挑啓動開始到啓動完成的第一條和最後一條日誌優化
這6秒中GC日誌打了69次, 而內存回收率仍是蠻高的 young區18880-1985=16895 jvm 46992-30098=16894 都快接近100%了,能夠看出young區是由小到大在不斷調整大小,因此不斷GC,所以設一個初始值吧,聽說設置heap的1/4比較好,那就是 128M,因此eclipse.ini加入ui
-Xmn128m |
再重啓,發現GC日誌就四條了,eclipse啓動天然快了
編碼
可是,啓動後open個人多個項目,這些項目互相依賴,eclipse自動build,感受有點小卡,發現日誌裏多了4次full GC,因此就卡了…spa
這個時候Tenured區和Perm都還沒到很接近最大值,可是爲何還有full GC呢,開始覺得是JVM悲觀認爲Tenured區剩餘空間不足以應對下一次minor GC 因此進行了full GC調整Tenured空間,索性直接增長了堆最大值到-Xmx728m(工做電腦的內存是3.5G),但重啓後full gc仍是有4次,並且有幾回minor GC用的時間超過了0.1秒,這是由於增長了堆大小,致使GC用時也增長了,不能接受。因此仍是改回-Xmx512m。
再仔細觀察日誌,發現Full GC (System) 字樣,這個意思是eclipse裏調用了System.gc()手動觸發了系統GC,好吧,哥已經給你分配足夠空間了,你就省省吧,在eclipse.ini里加入:線程
-XX:+DisableExplicitGC |
這樣就差很少了,整個過程沒有出現full gc,再編碼2個小時,中間只出現了一次full gc,在open build某50W行+的代碼的時候,eclipse仍是卡了…
最後又稍微調了一下各代的大小,獲得目前的參數:
-Xms512m |
-Xmx512m |
-XX:PermSize=96m |
-XX:MaxPermSize=96m |
-Xmn168m |
-XX:+DisableExplicitGC |
另外沒有去調GC策略,主要是以爲eclipse是客戶端程序,默認的client單線程的GC策略應該是比較適合的,之後有時間再試試看吧。