JDK8 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 或 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”
复制代码

八、辅助指令

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

复制代码
指令格式:jinfo -flag 参数 进程号

1、查看HeapDumpOnOutOfMemoryError 配置是否开启
jinfo -flag HeapDumpOnOutOfMemoryError 870778

2、修改HeapDumpOnOutOfMemoryError 配置(-关闭 +开启)
jinfo -flag +HeapDumpOnOutOfMemoryError 870778
复制代码

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

java -XX:+PrintFlagsInitial |grep GC

查看JVM所有参数

java -XX:+PrintFlagsInitial

九、常用启动参数
复制代码

JVM启动参数不换行

设置堆内存

‐Xmx4g ‐Xms4g

指定GC算法

‐XX:+UseG1GC ‐XX:MaxGCPauseMillis=50

指定GC并行线程数

‐XX:ParallelGCThreads=4

打印GC日志

‐XX:+PrintGCDetails ‐XX:+PrintGCDateStamps

指定GC日志文件

‐Xloggc:gc.log

指定Meta区的最大值

‐XX:MaxMetaspaceSize=2g

设置单个线程栈的大小

‐Xss1m

指定堆内存溢出时自动进行Dump

‐XX:+HeapDumpOnOutOfMemoryError
‐XX:HeapDumpPath=/usr/local/

此外,还有一些常用的属性配置:

指定默认的连接超时时间

‐Dsun.net.client.defaultConnectTimeout=2000
‐Dsun.net.client.defaultReadTimeout=2000

指定时区

‐Duser.timezone=GMT+08

设置默认的文件编码为UTF‐8

‐Dfile.encoding=UTF‐8

指定随机数熵源(Entropy Source)

‐Djava.security.egd=file:/dev/./urandom
复制代码

十、各种场景的参数设置方式
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

查看参数是否生效
jinfo -flag 参数 进程号

jinfo -flag HeapDumpOnOutOfMemoryError 1162

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java Development Kit (JDK)是Java开发工具包,而JVM参数是为Java虚拟机(JVM)配置的一组参数JDK8是Java 8版本的JDK,下面我将详细解释JDK8中常用JVM参数配置。 1. -Xms和-Xmx:这是设置JVM初始化堆内存和最大堆内存的参数。-Xms设定初始堆大小,-Xmx设定最大堆大小。例如,-Xms512m表示初始堆大小为512MB,-Xmx1024m表示最大堆大小为1GB。 2. -Xss:这是设置线程栈大小的参数。默认值根据操作系统和JVM版本而定。可以根据应用程序的需求进行调整。例如,-Xss256k表示线程栈的大小为256KB。 3. -XX:MetaspaceSize和-XX:MaxMetaspaceSize:这是设置元空间(Metaspace)初始大小和最大大小的参数。元空间是Java 8引入的一种取代永久代(PermGen)的存储区域。例如,-XX:MetaspaceSize=128m表示元空间的初始大小为128MB,-XX:MaxMetaspaceSize=256m表示元空间的最大大小为256MB。 4. -XX:NewSize、-XX:MaxNewSize和-XX:SurvivorRatio:这些是控制新生代(Young Generation)内存大小以及Eden区、Survivor区的比例的参数。新生代是堆内存的一部分,存放新创建的对象。可以通过调整这些参数来优化垃圾回收性能。 5. -XX:+UseParallelGC和-XX:+UseConcMarkSweepGC:这些是选择垃圾回收器的参数。Parallel GC(并行垃圾回收器)和CMS(并发标记清除垃圾回收器)是JDK8默认的两种垃圾回收器。分别用于在不同场景下提供更好的垃圾回收性能。 这些只是JDK8中常用JVM参数配置的一部分。根据实际需求,还有其他许多参数可以进行调整以达到最佳性能和稳定性。重要的是要了解这些参数,并根据应用程序的需求进行适当的配置

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值