chen4765654

          JVM參數(shù)配置

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


          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時(shí)的最佳實(shí)踐
          1、不要設(shè)置年輕代的大小(-Xmn),否則會(huì)擾亂G1的缺省行為,JVM也不會(huì)滿(mǎn)足用戶(hù)指定的暫停時(shí)間。而且設(shè)置了固定值的話(huà),G1將無(wú)法隨需擴(kuò)展年輕代的大小
          2、GC暫停時(shí)間不是100%能保證的
          3、如果GC的晉升過(guò)程中遇到堆區(qū)域溢出(使用-XX:+PrintGCDetails看到to-space overflow),可以通過(guò)下面幾種方式避免:
          增加-XX:G1ReservePercent=n,缺省值是10。這可以增加可用的to-space內(nèi)存
          使用-XX:ConcGCThreads=n增加標(biāo)記線(xiàn)程數(shù)目

          G1常用參數(shù)

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

          posted on 2015-09-18 17:52 紫色心情 閱讀(1253) 評(píng)論(0)  編輯  收藏 所屬分類(lèi): JAVA

          主站蜘蛛池模板: 美姑县| 肥城市| 简阳市| 镇原县| 安徽省| 鄂尔多斯市| 南宁市| 宜黄县| 剑阁县| 嵊州市| 安丘市| 沾化县| 桐柏县| 遂宁市| 桂平市| 江安县| 百色市| 汝州市| 鄯善县| 虹口区| 双城市| 甘谷县| 寿光市| 阿尔山市| 宣城市| 抚顺县| 改则县| 寻乌县| 高陵县| 稷山县| 东宁县| 黎平县| 房产| 张家界市| 西乌珠穆沁旗| 渭南市| 堆龙德庆县| 鸡东县| 扎鲁特旗| 蕉岭县| 昭平县|