ibm jdk 1.5缺省用的gc策略性能很差

          這幾天測(cè)試一個(gè)引擎的性能,用一個(gè)單表查詢的case,測(cè)試出來的結(jié)果是210tps,cpu也正常,在85%左右,也沒懷疑。

          后面再重新測(cè)試的時(shí)候,加上了gc log,用gc分析工具分析了一下gc的吞吐量,發(fā)現(xiàn)吞吐量奇低,竟然只有77%左右,很是奇怪,看了一下gc日志,所有都是global gc, 懷疑gc策略有問題,查了一下資料,參考了下面一篇文章:

          http://www.ibm.com/developerworks/cn/java/j-ibmjava2/

          缺省gc策略是針對(duì)吞吐量進(jìn)行優(yōu)化:-Xgcpolicy:optthruput ,對(duì)于吞吐量比短暫的 GC 停頓更重要的應(yīng)用程序,通常使用這種策略。每當(dāng)進(jìn)行垃圾收集時(shí),應(yīng)用程序都會(huì)停頓。

           

          我摘下面一段其他幾個(gè)gc策略:

          切換到其他 GC 策略的原因

          切換到
          原因

          optavgpause

          • 我的應(yīng)用程序無法忍受那么長(zhǎng)的 GC 停頓時(shí)間。如果 GC 停頓時(shí)間能夠減少的話,性能降低一些也可以接受。
          • 我的應(yīng)用程序正在一個(gè) 64 位平臺(tái)上運(yùn)行并使用非常大的堆 —— 超過 3 或 4GB。
          • 我的應(yīng)用程序是一個(gè) GUI 應(yīng)用程序,我很關(guān)注用戶響應(yīng)時(shí)間。

          gencon

          • 我的應(yīng)用程序分配了許多短期存活的對(duì)象。
          • 堆空間出現(xiàn)碎片化。
          • 我的應(yīng)用程序是基于事務(wù)的(也就是說,在事務(wù)提交之后,事務(wù)中的對(duì)象就不再存活了)。

          subpool

          • 在大型多處理器計(jì)算機(jī)上,我遇到了可伸縮性問題。

           

          試了一下gencon策略,hoho,好家伙,測(cè)試case的吞吐量竟然提升到290tps(直接提升40%),太夸張了,gc吞吐量也提升到了98%,記得以前1.4的時(shí)候沒有分代的gc策略,而且印象中,ibm jdk不分代,估計(jì)是引入分代機(jī)制之后,缺省的optthruput策略變得復(fù)雜起來,不像以前那樣效率高了。

           

          這里也給大家提個(gè)醒,當(dāng)心ibm jdk 1.5的gc策略,發(fā)現(xiàn)gc效率很低的時(shí)候切換到gencon,也許會(huì)有很大的驚喜!

          posted on 2008-04-14 20:38 tacy lee 閱讀(4456) 評(píng)論(2)  編輯  收藏 所屬分類: 性能相關(guān)

          評(píng)論

          # re: ibm jdk 1.5缺省用的gc策略性能很差 2008-04-17 23:51 syxlw

          請(qǐng)問使用什么工具來看gc吞吐量, 主要看哪個(gè)參數(shù)?  回復(fù)  更多評(píng)論   

          # re: ibm jdk 1.5缺省用的gc策略性能很差 2008-04-18 09:22 tacy lee

          用日志查看工具http://www.alphaworks.ibm.com/tech/pmat

          打開一個(gè)gc log文件,看里面的overall garbage collection overhead  回復(fù)  更多評(píng)論   

          主站蜘蛛池模板: 华亭县| 山阴县| 肇州县| 巴里| 丽江市| 福州市| 广汉市| 子洲县| 仁怀市| 西畴县| 马关县| 泉州市| 辽源市| 托克逊县| 长子县| 绵阳市| 始兴县| 普陀区| 保定市| 平原县| 深水埗区| 石屏县| 手游| 临清市| 钟山县| 星座| 永修县| 峨眉山市| 华亭县| 周至县| 军事| 栾城县| 垣曲县| 穆棱市| 界首市| 化德县| 嘉义县| 洛川县| 德江县| 孟州市| 正蓝旗|