chen4765654

          JVM參數配置

          set JAVA_OPTS=-server -Xmn4096m -Xms8192m -Xmx8192m -Xss256k -XX:PermSize=128m -XX:MaxPermSize=256m  -XX:SurvivorRatio=8 -XX:+UseCompressedOops -XX:+UseConcMarkSweepGC -XX:+CMSParallelRemarkEnabled -XX:+UseParNewGC  -XX:TargetSurvivorRatio=90 -XX:MaxTenuringThreshold=30 -XX:+UseCMSInitiatingOccupancyOnly -XX:CMSInitiatingOccupancyFraction=70 -XX:+DisableExplicitGC  -XX:+UseCMSCompactAtFullCollection -XX:CMSFullGCsBeforeCompaction=2 -XX:GCTimeRatio=20 -XX:SoftRefLRUPolicyMSPerMB=0 -Xnoclassgc -XX:LargePageSizeInBytes=128m -XX:+UseFastAccessorMethods

          –XX:ParallelGCThreads=20:設置 20 個線程進行垃圾回收;
          –XX:+UseParNewGC:年輕代使用并行回收器;
          –XX:+UseConcMarkSweepGC:年老代使用 CMS 收集器降低停頓;
          –XX:+SurvivorRatio:設置 Eden 區和 Survivor 區的比例為 8:1。稍大的 Survivor 空間可以提高在年輕代回收生命周期較短的對象的可能性,如果 Survivor 不夠大,一些短命的對象可能直接進入年老代,這對系統來說是不利的。
          –XX:TargetSurvivorRatio=90:設置 Survivor 區的可使用率。這里設置為 90%,則允許 90%的 Survivor 空間被使用。默認值是 50%。故該設置提高了 Survivor 區的使用率。當存放的對象超過這個百分比,則對象會向年老代壓縮。因此,這個選項更有助于將對象留在年輕代。
          –XX:MaxTenuringThreshold:設置年輕對象晉升到年老代的年齡。默認值是 15 次,即對象經過 15 次 Minor GC 依然存活,則進入年老代。這里設置為 31,目的是讓對象盡可能地保存在年輕代區域。
          -XX:GCTimeRatio
          通過-XX:GCTimeRatio=<value>我們告訴JVM吞吐量要達到的目標值。 更準確地說,-XX:GCTimeRatio=N指定目標應用程序線程的執行時間(與總的程序執行時間)達到N/(N+1)的目標比值。 例如,通過-XX:GCTimeRatio=9我們要求應用程序線程在整個執行時間中至少9/10是活動的(因此,GC線程占用其余1/10)。 基于運行時的測量,JVM將會嘗試修改堆和GC設置以期達到目標吞吐量。 -XX:GCTimeRatio的默認值是99,也就是說,應用程序線程應該運行至少99%的總執行時間


          JDK7可以用使用G1垃圾回收器,最好堆棧大于4G情況下使用。
          -Xmx24g -Xms24g -XX:PermSize=96m -XX:MaxPermSize=96m -XX:+UseG1GC -XX:SurvivorRatio=6 -XX:MaxGCPauseMillis=400 -XX:G1ReservePercent=15  -XX:InitiatingHeapOccupancyPercent=40 -XX:ConcGCThreads=8
          使用G1時的最佳實踐
          1、不要設置年輕代的大小(-Xmn),否則會擾亂G1的缺省行為,JVM也不會滿足用戶指定的暫停時間。而且設置了固定值的話,G1將無法隨需擴展年輕代的大小
          2、GC暫停時間不是100%能保證的
          3、如果GC的晉升過程中遇到堆區域溢出(使用-XX:+PrintGCDetails看到to-space overflow),可以通過下面幾種方式避免:
          增加-XX:G1ReservePercent=n,缺省值是10。這可以增加可用的to-space內存
          使用-XX:ConcGCThreads=n增加標記線程數目

          G1常用參數

          參數 描述
          -XX:+UseG1GC 開啟G1
          -XX:MaxGCPauseMillis=n 設置GC暫停的最大時間,這只是目標,盡量達到,默認值是 200 毫秒,過小影響吞吐量
          -XX:InitiatingHeapOccupancyPercent=n 整個堆(而不是某個年代)使用量達到此值,便會觸發并發GC周期.值為0則是連續觸發,默認值為45
          -XX:NewRatio=n 老年代與新生代的比值,默認值為2
          -XX:SurvivorRatio=n 伊甸園代與生存代的比率,默認值為8
          -XX:MaxTenuringThreshold=n 生存代存活的最大門限,默認值為15
          -XX:ParallelGCThreads=n 設置垃圾回收器并行階段的線程數,默認值與JVM運行的平臺有關,將 n 的值設置為邏輯處理器的數量
          -XX:ConcGCThreads=n 設置并發垃圾回收器使用的線程數,默認值與JVM運行的平臺有關
          -XX:G1ReservePercent=n 設置剩余的內存量,減少躍遷失敗的可能,默認值為10
          -XX:G1HeapRegionSize=n 設置G1平分java堆而產生區域的大小,默認值可以提供最大的工效性.最小值為1M,最大為32M,最多劃分1024個,建議使用默認值

          posted on 2015-09-18 17:52 紫色心情 閱讀(1254) 評論(0)  編輯  收藏 所屬分類: JAVA

          主站蜘蛛池模板: 冕宁县| 平武县| 沅江市| 芜湖市| 乐都县| 阿克苏市| 濮阳市| 陇西县| 鄂托克旗| 布拖县| 马龙县| 儋州市| 台东县| 万年县| 颍上县| 昔阳县| 吉林市| 高密市| 南丰县| 鄂伦春自治旗| 阿图什市| 郧西县| 三河市| 白河县| 固镇县| 陇西县| 柳河县| 固始县| 阿巴嘎旗| 道真| 绥中县| 株洲市| 军事| 芜湖县| 星子县| 四会市| 奉节县| 武隆县| 万年县| 龙岩市| 二连浩特市|