jvm 堆 比例_JVM调优原则
JVM調優原則
調優目標
將進入老年代的對象數量降到最低
減少 Full GC 的執行時間
在同樣場景下,采用多個機器上進行參數調整后的比較驗證,將驗證能夠提高性能的參數應用到最終所有服務器上。
一般常規
滿足下列不需要優化
Minor GC執行時間不到50ms;
Minor GC執行不頻繁,約10秒一次;
Full GC執行時間不到1s;
Full GC執行頻率不算頻繁,不低于10分鐘1次;
基本思想
針對JVM堆的設置
一般可以通過-Xms -Xmx限定其最小、最大值,為了防止垃圾收集器在最小、最大之間收縮堆而產生額外的時間,通常把最大、最小設置為相同的值;
年輕代和年老代
根據默認的比例(1:2)分配堆內存, 可以通過調整二者之間的比率NewRadio來調整二者之間的大小。
如年輕代,通過 -XX:newSize -XX:MaxNewSize來設置其絕對大小。同樣,為了防止年輕代的堆收縮,我們通常會把-XX:newSize -XX:MaxNewSize設置為同樣大小。
年輕代和年老代設置多大才參考:
更大的年輕代必然導致更小的年老代,大的年輕代會延長普通GC的周期,但會增加每次GC的時間,小的年老代會導致更頻繁的Full GC。
更小的年輕代必然導致更大年老代,小的年輕代會導致普通GC很頻繁,但每次的GC時間會更短,大的年老代會減少Full GC的頻率。
如何選擇應該依賴應用程序對象生命周期的分布情況:如果應用存在大量的臨時對象,應該選擇更大的年輕代;如果存在相對較多的持久對象,年老代應該適當增大。但很多應用都沒有這樣明顯的特性。
在抉擇時應該根據以下兩點:
本著Full GC盡量少的原則,讓年老代盡量緩存常用對象,JVM的默認比例1:2也是這個道理 。
通過觀察應用一段時間,看其他在峰值時年老代會占多少內存,在不影響Full GC的前提下,根據實際情況加大年輕代,比如可以把比例控制在1:1。但應該給年老代至少預留1/3的增長空間。
配置較好的機器
比如多核、大內存機器,可以為年老代選擇并行收集算法:-XX:+UseParallelOldGC 。
線程堆棧的設置
每個線程默認會開啟1M的堆棧,用于存放棧幀、調用參數、局部變量等,對大多數應用而言這個默認值太了,一般256K就足用。
理論上,在內存不變的情況下,減少每個線程的堆棧,可以產生更多的線程,但這實際上還受限于操作系統。
如果你覺得文章不錯,文末的贊 ? 又回來啦,記得給我「點贊」和「在看」哦~總結
以上是生活随笔為你收集整理的jvm 堆 比例_JVM调优原则的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 真正聪明的人,为什么从不去社交?
- 下一篇: 新一配:iPod及其系列产品【转载】