jvm学习的尾声(六)---常用jvm配置参数总结

JVM的常用配置项

在jvm参数配置中,+为增加配置,-为去除该配置

1.堆的常用指令

 设置堆初始值
 指令1-Xms2g
 指令2-XX:InitialHeapSize=2048m
 ​
 ​
 设置堆区最大值
 指令1-Xmx2g
 指令2-XX:MaxHeapSize=2048m
 缩小堆内存的时机
 -XX:MaxHeapFreeRatio=70//堆内存使用率大于70时扩张堆内存,xms=xmx时该参数无效,默认值70
 ​
 ​
 扩张堆内存的时机
 -XX:MinHeapFreeRatio=40//堆内存使用率小于40时缩减堆内存,xms=xmx时该参数无效,默认值40
 ​
 ​
 新生代内存配置
 指令1-Xmn512m
 指令2-XX:MaxNewSize=512m
 ​
 ​
 2个survivor区和Eden区大小比率
 指令:-XX:SurvivorRatio=6  //S区和Eden区占新生代比率为1:6,两个S区2:6
 ​
 ​
 新生代和老年代的占比
 -XX:NewRatio=4  //表示新生代:老年代 = 1:4 即老年代占整个堆的4/5;默认值=2)

2.方法区的常用指令

初始化的Metaspace大小,
 -XX:MetaspaceSize :
 ​
 Metaspace最大值
 -XX:MaxMetaspaceSize

3.配置垃圾回收器

 Serial垃圾收集器(新生代)
 开启:-XX:+UseSerialGC
 关闭:-XX:-UseSerialGC
 //新生代使用Serial  老年代则使用SerialOldParNew垃圾收集器(新生代)
 开启 -XX:+UseParNewGC
 关闭 -XX:-UseParNewGC
 //新生代使用功能ParNew 老年代则使用功能CMSParallel Scavenge收集器(新生代)
 开启 -XX:+UseParallelOldGC
 关闭 -XX:-UseParallelOldGC
 //新生代使用功能Parallel Scavenge 老年代将会使用Parallel Old收集器ParallelOl垃圾收集器(老年代)
 开启 -XX:+UseParallelGC
 关闭 -XX:-UseParallelGC
 //新生代使用功能Parallel Scavenge 老年代将会使用Parallel Old收集器CMS垃圾收集器(老年代)
 开启 -XX:+UseConcMarkSweepGC
 关闭 -XX:-UseConcMarkSweepGCG1垃圾收集器
 开启 -XX:+UseG1GC
 关闭 -XX:-UseG1GC

4.GC策略配置

parallelGc并发线程数
 -XX:ParallelGCThreads=16
 
 新生代最大年龄对象数量设限
 -XX:PretenureSizeThreshold=1000000 //大于此值的对象直接会分配到老年代,设置为0则没有限制。
     //避免在Eden区和Survivor区发生大量的内存复制,该参数只对Serial和ParNew收集器有效,Parallel Scavenge并不认识该参数

年龄设限
 进入老年代最小的GC年龄
 -XX:InitialTenuringThreshol=7 //年轻代对象转换为老年代对象最小年龄值,默认值7,对象在坚持过一次Minor GC之后,年龄就加1,每个对象在坚持过一次Minor GC之后,年龄就增加1
 ​​
 进入老年代最大的GC年龄
 -XX:MaxTenuringThreshold=15 //年轻代对象转换为老年代对象最大年龄值,默认值15

5.配置GC日志

 -Xloggc:/data/gclog/gc.log//固定路径名称生成
 -Xloggc:/home/GCEASY/gc-%t.log //根据时间生成
 
 日志文件达到一定大小后,生成另一个文件。须配置Xloggc
  开启 -XX:+UseGCLogFileRotation
  关闭 -XX:-UseGCLogFileRotation-XX:NumberOfGCLogFiles=4   //滚动GC日志文件数,默认0,不滚动
 -XX:GCLogFileSize=100k  //GC文件滚动大小,需配置UseGCLogFileRotation,设置为0表示仅通过jcmd命令触发
 
 打印gc日志信息
 开启 -XX:+PrintGCDetails
 关闭 -XX:-PrintGCDetails
 
 打印应用暂停时间
 开启 -XX:+PrintGCApplicationStoppedTime
 关闭 -XX:-PrintGCApplicationStoppedTime

 打印堆细节
 开启 -XX:+PrintHeapAtGC
 关闭 -XX:-PrintHeapAtGC
 
 打印存活实例年龄
 开启 -XX:+PrintTenuringDistribution
 关闭 -XX:-PrintTenuringDistribution

OutOfMemory异常时输出文件
 开启 -XX:+HeapDumpOnOutOfMemoryError
 关闭 -XX:-HeapDumpOnOutOfMemoryError
 //可以通过jinfo -flag [+|-]HeapDumpOnOutOfMemoryError <pid> 或 jinfo -flag HeapDumpOnOutOfMemoryError=<value> <pid> 来动态开启或设置值
 ​​
 -XX:HeapDumpPath=/data/dump/jvm.dump//设置文件路径
 //当HeapDumpOnOutOfMemoryError开启的时候,dump文件的保存路径,默认为工作目录下的
 
Full GC生成dump文件
 -XX:+HeapDumpBeforeFullGC       //实现在Full GC前dump
 -XX:+HeapDumpAfterFullGC        //实现在Full GC后dump。
 -XX:HeapDumpPath=e:\dump        //设置Dump保存的路径

6.辅助指令

查看HeapDumpOnOutOfMemoryError 配置是否开启
jinfo -flag HeapDumpOnOutOfMemoryError 870778

修改HeapDumpOnOutOfMemoryError 配置(-关闭 +开启)
 jinfo -flag +HeapDumpOnOutOfMemoryError 870778

模糊查找指令
java -XX:+PrintFlagsInitial |grep GC

查看JVM所有参数
 java -XX:+PrintFlagsInitial

猜你喜欢

转载自blog.csdn.net/faker1234546/article/details/129097441