dockerfile tomcat 配置jvm参数_JVM实战:JVM常用参数配置

本篇主要了解下面内容:

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

9c674d9d34867ab86ca174d2a27d9965.png

bfa7e591061fbc606365c996f6b94bb8.png

Tomcat

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

JAVA_OPTS

1604760502381621a610caf6dccffc93.png

jar包

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

nohup 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值