本篇主要了解下面内容:
1、JVM常用的配置参数如、内存配置参数、GC策略配置参数、日志配置参数、异常信息参数。
2、CMS、G1的常用个性化参数。
3、常用的一些应用启动参数,在项目启动的时候我们需要配置哪些参数。
4、各种部署场景下通过什么方式配置这些参数。
1、堆内存配置参数
有时候我们需要根据GC的情况实时情况,动态调整各个区域的大小,所以会配置JVM内存各个区域的内存大小是我们经常会用到的配置参数。
//设置堆初始值
2、垃圾收集器配置
Serial垃圾收集器3、GC策略配置
4、GC日志配置
java
-XX:+PrintGCDetails -XX:+PrintGCDateStamps
-XX:+UseGCLogFileRotation
-XX:+PrintHeapAtGC -XX:NumberOfGCLogFiles=5
-XX:GCLogFileSize=20M
-Xloggc:/opt/ard-user-gc-%t.log
-jar abg-user-1.0-SNAPSHOT.jar -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的原因(默认开启)5、cms常用参数
//CMS并发标记和搜集线程数量
-XX:ParallelCMSThreads
//使用多少比例的老年代后开始CMS收集,默认是68%,如果频繁发生SerialOld卡顿,应该调小
-XX:CMSInitiatingOccupancyFraction
//在FGC时进行压缩
-XX:+UseCMSCompactAtFullCollection
/多少次FGC之后进行压缩
-XX:CMSFullGCsBeforeCompaction
//达到什么比例时进行Perm回收
-XX:CMSInitiatingPermOccupancyFraction
//垃圾回收时是否同时卸载不用的class信息,默认关闭
-XX:+CMSClassUnloadingEnabled
6、G1常用参数
//设置Region大小,建议逐渐增大该值,1 2 4 8 16 32。 增大会使垃圾的存活时间更长,GC次数减少,单次GC的时间增加
-XX:+G1HeapRegionSize
//新生代最小比例,默认为5%
G1NewSizePercent
//新生代最大比例,默认为60%
G1MaxNewSizePercent
//设置并发标记的GC线程数。 默认值约等于 ParallelGCThreads 值的 1/4。
-XX:ConcGCThreads
//G1不会回收的内存大小,默认是堆大小的5%。GC会收集所有的Region,如果值达到5%,就会停下来不再收集了
-XX:G1HeapWastePercent
//混合垃圾回收周期中要包括的旧区域设置占用率阈值。默认占用率为 65%
-XX:G1MixedGCLiveThresholdPercent=65
7、dump 日志参数配置
OutOfMemory异常时生成dump文件
开启 在Full GC时生成dump文件
-8、常用启动参数
设置堆内存大小
设置堆内存大小,Xms 最小内存,Xmx最大内存,不设置默认为物理机内存的四分之一。
-Xms2g -Xmx2g` GC日志参数
生成GC滚动日志记录 ,当需要对GC排查问题时候需要对此日志分析。
-XX:+PrintGCDetails -XX:+PrintGCDateStamps -XX:+UseGCLogFileRotation -XX:+PrintHeapAtGC -XX:NumberOfGCLogFiles=5 -XX:GCLogFileSize=50M -Xloggc:/opt/emps-gc-%t.log -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/opt/dump/emps-heap.dump
-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的原因(默认开启)异常时记录内存日志
抛出内存溢出错误时导出堆信息到指定文件,内存溢出时需要对此日志进行分析
-XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/data/dump/jvm.dump
HeapDumpOnOutOfMemoryError 异常后打印堆内存信息
HeapDumpPath 生成的堆内存日志的路径案例
nohup java -XX:+PrintGCDetails -XX:+PrintGCDateStamps -XX:+UseGCLogFileRotation -XX:+PrintHeapAtGC -XX:NumberOfGCLogFiles=5 -XX:GCLogFileSize=50M -Xloggc:/opt/emps-gc-%t.log -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/opt/emps-heap.hprof -jar user-1.0-SNAPSHOT.jar&
9、各种场景的参数设置方式
Idea


Tomcat
linux 在tomcat 的bin目录下catalina.sh 文件里增加配置参数
JAVA_OPTS
jar包
直接在启动命令跟对应参数
nohup
本文深入探讨了JVM的常用配置参数,包括内存配置、GC策略、日志设置以及CMS和G1垃圾收集器的个性化参数。重点讲解了如何动态调整堆内存大小、配置垃圾收集器、设置GC日志以及CMS和G1的相关参数。同时,提到了在不同部署场景下配置参数的方法,以及如何在出现OutOfMemory异常时生成堆内存dump文件。此外,还介绍了启动参数的设置,如堆内存大小和GC日志记录。
1164

被折叠的 条评论
为什么被折叠?



