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

本文主要了解下面内容:

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

2、通过一些辅助指令可以帮助我们查找参数的指令,以及在运行期间查看和更改一些参数配置。

3、常用的一些应用启动参数,在项目启动的时候我们需要配置哪些参数。

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

一、堆内存相关配置

 设置堆初始值
 指令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
 ​

二、方法区内存配置常用参数

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

三、线程栈内存配置常用参数

每个线程栈最大值

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

注意:

栈设置太大,会导致线程创建减少。

栈设置小,会导致深入不够,深度的递归会导致栈溢出。

建议栈深度设置在3000-5000


四、配置垃圾收集器

 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

五、GC策略配置

GC并行执行线程数

 -XX:ParallelGCThreads=16

新生代可容纳的最大对象

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

进入老年代的GC年龄

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

六、GC日志信息配置

配置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日志

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

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

打印应用暂停时间

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

每次GC完成后,打印出JVM堆内存每个区域的使用情况

 开启 -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保存的路径
 JAVA_OPTS="-XX:+HeapDumpOnOutOfMemoryError  -XX:HeapDumpPath=/data/dump/jvm.dump"
   

八、辅助指令

查看或修改正在运行的JVM 某项配置

指令格式:jinfo -flag 参数 进程号

1、查看HeapDumpOnOutOfMemoryError 配置是否开启

 jinfo -flag HeapDumpOnOutOfMemoryError 870778

2、修改HeapDumpOnOutOfMemoryError 配置(-关闭 +开启)

 jinfo -flag +HeapDumpOnOutOfMemoryError 870778

模糊查找指令

如果忘记了某个指令的全名,可根据部分单词匹配查找

 java -XX:+PrintFlagsInitial |grep GC

查看JVM所有参数

 java -XX:+PrintFlagsInitial

九、常用启动参数

1、设置堆内存大小

设置堆内存大小,Xms 最小内存,Xmx最大内存,不设置默认为物理机内存的四分之一。

 -Xms2g   -Xmx2g`     

2、GC日志参数

生成GC滚动日志记录 ,当需要对GC排查问题时候需要对此日志分析。

 -XX:+PrintGCDetails -XX:+PrintGCDateStamps -XX:+UseGCLogFileRotation  -XX:+PrintHeapAtGC -XX:NumberOfGCLogFiles=5 -XX:GCLogFileSize=20M    -Xloggc:/opt/ard-user-gc-%t.log 
 -Xloggc:/opt/app/ard-user/ard-user-gc-%t.log   设置日志目录和日志名称
 -XX:+UseGCLogFileRotation           开启滚动生成日志
 -XX:NumberOfGCLogFiles=5            滚动GC日志文件数,默认0,不滚动
 -XX:GCLogFileSize=20M               GC文件滚动大小,需开启UseGCLogFileRotation
 -XX:+PrintGCDetails                 开启记录GC日志详细信息(包括GC类型、各个操作使用的时间),并且在程序运行结束打印出JVM的内存占用情况
 -XX:+ PrintGCDateStamps             记录系统的GC时间           
 -XX:+PrintGCCause                   产生GC的原因(默认开启)

3、异常时记录内存日志

抛出内存溢出错误时导出堆信息到指定文件,内存溢出时需要对此日志进行分析

 -XX:+HeapDumpOnOutOfMemoryError  -XX:HeapDumpPath=/data/dump/jvm.dump
 HeapDumpOnOutOfMemoryError  异常后打印堆内存信息
 HeapDumpPath                生成的堆内存日志的路径

十、各种场景的参数设置方式

Idea

318ce64cb6c372710de6870c31d0d58e.png

8292b3dea141ee60c2a5dfe2103c7ef8.png

Tomcat

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

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

09ab7052df11378a4e730883d55c7bc0.png

jar包

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

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

查看参数是否生效

jinfo -flag 参数 进程号

jinfo -flag HeapDumpOnOutOfMemoryError 1162

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值