jvm对象从新生代到老年代_JVM常用配置参数

本文主要了解下面内容:

1、JVM常用的配置参数如、内存配置参数、GC策略配置参数、日志配置参数、异常信息参数。

2、了解哪些参数必须在启动时设置,哪些是在运行时可以更改的。

3、各种部署场景下通过什么方式配置这些参数。


内存配置参数

主要包括堆内存、方法区、线程栈的内存分配参数。

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、线程栈内存配置

每个线程栈最大值

指令1:-Xss256k
​
指令2:-XX:ThreadStackSize=256k

GC策略配置参数

1、配置垃圾收集器

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

2、GC并行执行线程数

-XX:ParallelGCThreads=16

3、新生代可容纳的最大对象

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

4、进入老年代的GC年龄

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

GC日志信息配置

1、配置GC文件路径

-Xloggc:/data/gclog/gc.log//固定路径名称生成
-Xloggc:/home/GCEASY/gc-%t.log //根据时间生成

2、滚动生成日志

日志文件达到一定大小后,生成另一个文件。须配置Xloggc

开启 -XX:+UseGCLogFileRotation
关闭 -XX:-UseGCLogFileRotation
​
-XX:NumberOfGCLogFiles=4   //滚动GC日志文件数,默认0,不滚动
-XX:GCLogFileSize=100k  //GC文件滚动大小,需配置UseGCLogFileRotation,设置为0表示仅通过jcmd命令触发

3、打印详细的GC日志

打印GC的详细日志,并且在程序运行结束是会打印出JVM的内存占用情况

开启 -XX:+PrintGCDetails
关闭 -XX:-PrintGCDetails

4、打印垃圾回收期间程序暂停的时间

开启 -XX:+PrintGCApplicationStoppedTime
关闭 -XX:-PrintGCApplicationStoppedTime

5、GC的时候打印区使用信息

开启 -XX:+PrintHeapAtGC
关闭 -XX:-PrintHeapAtGC

6、打印存活实例年龄信息

开启 -XX:+PrintTenuringDistribution
关闭 -XX:-PrintTenuringDistribution

条件触发配置

1、OutOfMemory异常时输出文件

抛出内存溢出错误时导出堆信息到指定文件

开启 -XX:+HeapDumpOnOutOfMemoryError
关闭 -XX:-HeapDumpOnOutOfMemoryError
//可以通过jinfo -flag [+|-]HeapDumpOnOutOfMemoryError  或 jinfo -flag HeapDumpOnOutOfMemoryError=  来动态开启或设置值
​
​
-XX:HeapDumpPath=/data/dump/jvm.dump//设置文件路径
//当HeapDumpOnOutOfMemoryError开启的时候,dump文件的保存路径,默认为工作目录下的

2、在Full GC时生成dump文件

-XX:+HeapDumpBeforeFullGC       //实现在Full GC前dump
-XX:+HeapDumpAfterFullGC        //实现在Full GC后dump。
-XX:HeapDumpPath=e:dump        //设置Dump保存的路径

补充

1、查看JVM所有参数

指令:java -XX:+PrintFlagsInitial

3、查看可以哪些参数在运行期间可以修改的

指令:java -XX:+PrintFlagsInitial |grep manageable

各种场景的参数设置方式

Idea

jvm对象从新生代到老年代_JVM常用配置参数_第1张图片

jvm对象从新生代到老年代_JVM常用配置参数_第2张图片

Tomcat

linux 在tomcat 的bin目录下catalina.sh 文件里增加配置参数

JAVA_OPTS="-Xms1024m -Xmx4096m -Xss1024K -XX:PermSize=512m -XX:MaxPermSize=2048m"

jar包

直接在启动命令跟对应参数

nohup java -jar -XX:InitialHeapSize=30m   jstx-server.jar

你可能感兴趣的:(jvm对象从新生代到老年代)