日本熟妇hd丰满老熟妇,中文字幕一区二区三区在线不卡 ,亚洲成片在线观看,免费女同在线一区二区

JVM參數配置說明

本文從堆棧內存、回收器GC兩方面介紹常見的JVM參數并提供配置示例。

調優堆棧內存

堆棧大小典型配置參數

配置參數

說明

示例

-Xmx

設置最大堆大小。

-Xmx3550m,設置JVM最大可用內存為3550 MB。

-Xms

設置JVM初始內存。

-Xms3550m,設置JVM初始內存為3550 MB。此值建議與-Xmx相同,避免每次垃圾回收完成后JVM重新分配內存。

-Xmn

設置年輕代大小。

-Xmn2g,設置年輕代大小為2 GB。整個JVM內存大小=年輕代大小+年老代大小+持久代大小。持久代一般固定大小為64 MB,所以增大年輕代后,將會減小年老代大小。此值對系統性能影響較大,Sun官方推薦配置為整個堆的3/8。

-Xss

設置線程的棧大小。

-Xss128k,設置每個線程的棧大小為128 KB。

說明

JDK 5.0版本以后每個線程棧大小為1 MB,JDK 5.0以前版本每個線程棧大小為256 KB。請依據應用的線程所需內存大小進行調整。在相同物理內存下,減小該值可以生成更多的線程。但是操作系統對一個進程內的線程個數有一定的限制,無法無限生成,一般在3000個~5000個。

-XX:NewRatio=n

設置年輕代和年老代的比值。

-XX:NewRatio=4,設置年輕代(包括Eden和兩個Survivor區)與年老代的比值(除去持久代)。如果設置為4,那么年輕代與年老代所占比值為1:4,年輕代占整個堆棧的1/5。

-XX:SurvivorRatio=n

年輕代中Eden區與兩個Survivor區的比值。

-XX:SurvivorRatio=4,設置年輕代中Eden區與Survivor區的大小比值。如果設置為4,那么兩個Survivor區與一個Eden區的比值為2:4,一個Survivor區占整個年輕代的1/6。

-XX:MaxPermSize=n

設置持久代大小。

-XX:MaxPermSize=16m,設置持久代大小為16 MB。

-XX:MaxTenuringThreshold=n

設置垃圾最大年齡。

-XX:MaxTenuringThreshold=0,設置垃圾最大年齡。

  • 如果設置為0,那么年輕代對象不經過Survivor區,直接進入年老代。對于年老代比較多的應用,提高了效率。

  • 如果將此值設置為較大值,那么年輕代對象會在Survivor區進行多次復制,增加了對象在年輕代的存活時間,增加在年輕代即被回收的概率。

調優回收器GC(Garbage Collection)

吞吐量優先的GC典型配置參數

配置參數

說明

示例

-XX:+UseParallelGC

選擇垃圾收集器為并行收集器。

-Xmx3800m -Xms3800m -Xmn2g -Xss128k -XX:+UseParallelGC -XX:ParallelGCThreads=20-XX:+UseParallelGC此配置僅對年輕代有效,即在示例配置下,年輕代使用并發收集,而年老代仍舊使用串行收集。

-XX:ParallelGCThreads

配置并行收集器的線程數,即同時多少個線程一起進行垃圾回收。

說明

此值建議配置與處理器數目相等。

-Xmx3800m -Xms3800m -Xmn2g -Xss128k -XX:+UseParallelGC -XX:ParallelGCThreads=20-XX:ParallelGCThreads=20表示配置并行收集器的線程數為20個。

-XX:+UseParallelOldGC

配置年老代垃圾收集方式為并行收集。

說明

JDK 6.0支持對年老代并行收集。

-Xmx3550m -Xms3550m -Xmn2g -Xss128k -XX:+UseParallelGC -XX:ParallelGCThreads=20 -XX:+UseParallelOldGC-XX:+UseParallelOldGC表示對年老代進行并行收集。

-XX:MaxGCPauseMillis

設置每次年輕代垃圾回收的最長時間,如果無法滿足此時間,JVM會自動調整年輕代大小,以滿足此值。

-Xmx3550m -Xms3550m -Xmn2g -Xss128k -XX:+UseParallelGC -XX:MaxGCPauseMillis=100-XX:MaxGCPauseMillis=100設置每次年輕代垃圾回收的最長時間為100 ms。

-XX:+UseAdaptiveSizePolicy

設置此選項后,并行收集器自動選擇年輕代區大小和相應的Survivor區比例,以達到目標系統規定的最低響應時該間或者收集頻率,該值建議使用并行收集器時,并且一直打開。

-Xmx3550m -Xms3550m -Xmn2g -Xss128k -XX:+UseParallelGC -XX:MaxGCPauseMillis=100 -XX:+UseAdaptiveSizePolicy

響應時間優先的GC典型配置參數

配置參數

說明

示例

-XX:+UseConcMarkSweepGC

設置年老代為并發收集。

說明

配置了-XX:+UseConcMarkSweepGC,建議年輕代大小使用-Xmn設置。

-Xmx3550m -Xms3550m -Xmn2g -Xss128k -XX:ParallelGCThreads=20 -XX:+UseConcMarkSweepGC -XX:+UseParNewGC

-XX:+UseParNewGC

設置年輕代為并行收集。

可與CMS收集同時使用。JDK 5.0以上版本,JVM根據系統配置自行設置,無需再設置此值。

-Xmx3550m -Xms3550m -Xmn2g -Xss128k -XX:ParallelGCThreads=20 -XX:+UseConcMarkSweepGC -XX:+UseParNewGC

-XX:CMSFullGCsBeforeCompaction

由于并發收集器不對內存空間進行壓縮、整理,所以運行一段時間以后會產生“碎片”,使得運行效率降低。此值設置運行多少次GC以后對內存空間進行壓縮、整理。

-Xmx3550m -Xms3550m -Xmn2g -Xss128k -XX:+UseConcMarkSweepGC -XX:CMSFullGCsBeforeCompaction=5 -XX:+UseCMSCompactAtFullCollection-XX:CMSFullGCsBeforeCompaction=5,表示運行GC5次后對內存空間進行壓縮、整理。

-XX:+UseCMSCompactAtFullCollection

打開對年老代的壓縮。

說明

該值可能會影響性能,但是可以消除碎片。

-Xmx3550m -Xms3550m -Xmn2g -Xss128k -XX:+UseConcMarkSweepGC -XX:CMSFullGCsBeforeCompaction=5 -XX:+UseCMSCompactAtFullCollection

用于輔助的GC典型配置參數

配置參數

說明

-XX:+PrintGC

用于輸出GC日志。

-XX:+PrintGCDetails

用于輸出GC日志詳情。

-XX:+PrintGCTimeStamps

用于輸出GC時間戳(JVM啟動到當前日期的總時長的時間戳形式)。示例如下:

0.855: [GC (Allocation Failure) [PSYoungGen: 33280K->5118K(38400K)] 33280K->5663K(125952K), 0.0067629 secs] [Times: user=0.01 sys=0.01, real=0.00 secs]

-XX:+PrintGCDateStamps

用于輸出GC時間戳(日期形式)。示例如下:

2022-01-27T16:22:20.885+0800: 0.299: [GC pause (G1 Evacuation Pause) (young), 0.0036685 secs]

-XX:+PrintHeapAtGC

在進行GC前后打印出堆的信息。

-Xloggc:../logs/gc.log

日志文件的輸出路徑。