个人常用的JVM命令记录以下,方便后面查阅
首先通过-XX:+PrintFlagsFinal查看默认参数配置作一个对比
监控方面的:
1.打印GC详情
-XX:+PrintGCDetails
2.打印GC时间
-XX:+PrintGCDateStamps
3.GC前后打印堆情况
-XX:+PrintHeapAtGC
4.打印GC之间应用运行的时间
-XX:+PrintGCApplicationCurrentTime
5.GC造成的停顿时间
-XX:+PrintGCApplicationStoppedTime
6.打印各个Age的对象的总大小 (分析动态年龄)
-XX:+PrintTenuringDistribution
内存配置:
1.堆最小内存
-Xms8g
2.堆最大内存
-Xmx8g
3.设置年轻代和老年代内存比值
-XX:NewRatio=2
4.年轻代内存分配比率
-XX:SurvivorRatio=8
5.最大栈大小
-Xss1m
优化相关:
1.关闭偏向锁(对于RocketMq,竞争比较多,偏向锁的场景比较少可以关闭,减少撤销停顿)
-XX:-UseBiasedLocking
2.对象生存年龄(默认15,对象头分带年龄为4个字节,所以最大也是4个字节)
-XX:MaxTenuringThreShold=15
3.优化getter,setter,编译为本地代码
-XX:+UseFastAccessorMethods
4…指定大对象直接进入老年代
-XX:PetenureSizeThreshold=1m
5.操作系统将内存正在分配给jvm。否则每个缓存页上分配内存就会慢,如果是yGC需要晋升到老年代时会延长GC停顿时间。
副作用就是jvm启动时间会大幅加长。幅度随申请的堆大小内存增大而增大。
-XX:+AlwaysPreTouch
CMS优化
1.开启CMS收集器
-XX:+UseConcMarkSweepGC
2.开启并发remark,减少停顿时间
-XX:+CMSParallelRemarkEnable
3.FUllGC后对内存碎片进行规整
-XX:+UseCMSCompactAtFullCollection
通常需要搭配 -XX:CMSFullGCsBeforeCompaction=5 使用,表示3次fullGC后进行一次规整
4.设定回收阀值,比如到达70%时进行cms回收
-XX:+UseCMSInitiatingOccupancyOnly
通常搭配:
-XX:CMSInitiatingOccupancyFraction=70
指定回收阀值(即指定预留空间)
promotion failed(survivor区放不下)
concurrent mode failure (cms收集过程中,老年代内存不足)
G1优化
1.开启G1收集器
-XX:+UseG1GC
2.禁用-Xmn,-XX:newRatio= 否则会导致目标停顿时间无法满足,年轻代不能动态伸缩
3.设置最大停顿时间 jvm会努力达到此目标 90%以上
-XX:MaxGCPauseMillis=200
4.设置G1每个Region的大小 1-32m 如果有多个巨型对象分配失败触发fullGC可以调大次参数
-XX:+G1HeapRegionSize=16
5.触发标记周期使用的堆占整堆的内存大小,如果经常出现to-space overflow(疏散失败)或晋升失败造成的fullGC时可以调小一点,使得复制时有足够的空余内存
-XX:+InitiatingHeapOccupancyPercent=30
6.stw并发线程数
-XX:ParallelGCThreads=8
7.设置并发标记线程数
-XX:ConcGCThreads=2;
8.并发模式失败需要加大堆大小(mixedGC之前)
10.预留内存,防止to-space overflow 默认10。如果出现此问题要么加堆,要么多预留
-XX:G1ReservePercent=25