java -jar 设置jvm参数_JVM实战:JVM常用参数配置

本篇主要了解下面内容:

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

2、CMS、G1的常用个性化参数。

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

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

1、堆内存配置参数

有时候我们需要根据GC的情况实时情况,动态调整各个区域的大小,所以会配置JVM内存各个区域的内存大小是我们经常会用到的配置参数。

//设置堆初始值 指令1:-Xms2g

指令2:-XX:InitialHeapSize=2048m

//设置堆区最大值 指令1:`-Xmx2g`

指令2: -XX:MaxHeapSize=2048m

//设置线程栈的大小 指令1:-Xss256k

指令2:-XX:ThreadStackSize=256k

//新生代内存配置 指令1:-Xmn512m

指令2:-XX:MaxNewSize=512m

//缩小堆内存的时机 -XX:MaxHeapFreeRatio=70//堆内存使用率大于70时扩张堆内存,如果最大堆内存=初始堆内存时该参数无效,默认值70 //扩张堆内存的时机 -XX:MinHeapFreeRatio=40//堆内存使用率小于40时缩减堆内存,如果最大堆内存=初始堆内存时该参数无效,默认值40 ​

//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

2、垃圾收集器配置

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

3、GC策略配置

//GC停顿时间,垃圾收集器会尝试用各种手段达到这个时间,比如减小年轻代 -XX:MaxGCPauseMillis

//堆占用了多少比例的时候触发GC,就即触发标记周期的 Java 堆占用率阈值。默认占用率是整个 Java 堆的 45% -XX:InitiatingHeapOccupancyPercent=n

//新生代可容纳的最大对象,大于则直接会分配到老年代,0代表没有限制。 -XX:PretenureSizeThreshold=1000000 //

//进入老年代最小的GC年龄,年轻代对象转换为老年代对象最小年龄值,默认值7 -XX:InitialTenuringThreshol=7

//升级老年代年龄,最大值15 -XX:MaxTenuringThreshold

//GC并行执行线程数 -XX:ParallelGCThreads=16

//禁用 System.gc() //由于该方法默认会触发 FGC,并且忽略参数中的 UseG1GC 和 UseConcMarkSweepGC,因此必要时可以禁用该方法。 -XX:-+DisableExplicitGC

//设置吞吐量大小,默认99 XX:GCTimeRatio

//打开自适应策略,各个区域的比率,晋升老年代的年龄等参数会被自动调整。以达到吞吐量,停顿时间的平衡点。 XX:UseAdaptiveSizePolicy

//设置GC时间占用程序运行时间的百分比 GCTimeRatio

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文件

开启 -XX:+HeapDumpOnOutOfMemoryError

关闭 -XX:-HeapDumpOnOutOfMemoryError

//可以通过jinfo -flag [+|-]HeapDumpOnOutOfMemoryError 或 jinfo -flag HeapDumpOnOutOfMemoryError= 来动态开启或设置值 ​

-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"

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="-Xms1024m -Xmx4096m -Xss1024K -XX:PermSize=512m -XX:MaxPermSize=2048m"

jar包

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

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

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值