当前位置:网站首页>JVM——》常用参数
JVM——》常用参数
2022-04-23 10:05:00 【小仙。】
一、参数查询
执行:
java -XX:+PrintFlagsFinal
注意:
= 表示默认值
:= 表示被JVM或者用户修改后的值

二、参数分类
1、标准参数
-version
-help
-server
-cp

2、-X参数(非标准,JDK各个版本中可能会变动)
-Xint 解释执行
-Xcomp 第一次使用就编译成本地代码
-Xmixed 混合模式,JVM自己来决定

3、-XX参数(非标准,相对不稳定,主要用于JVM调优)
1)Boolean类型
格式:
-XX:[+-]<name>
注意:
+ 表示启用name属性
- 表示禁用name属性
示例:
-XX:+UseConcMarkSweepGC 表示启用CMS类型的垃圾回收器
-XX:+UseG1GC 表示启用G1类型的垃圾回收器
2)非Boolean类型
格式:
-XX<name>=<value>
注意:
name属性的值是value
示例:
-XX:MaxGCPauseMillis=500
4、其他参数(简写参数)
-Xms1000M 等价于 -XX:InitialHeapSize=1000M
-Xmx1000M 等价于 -XX:MaxHeapSize=1000M
-Xss100 等价于 -XX:ThreadStackSize=100
三、常用参数
| 参数 | 含义 | 说明 |
|---|---|---|
| -XX:CICompilerCount=3 | 最大并行编译数 | 如果设置大于1,虽然编译速度会提高,但是同样影响系统稳定性,会增加JVM崩溃的可能 |
| -XX:InitialHeapSize=100M | 初始化堆大小 | 简写-Xms100M |
| -XX:MaxHeapSize=100M | 最大堆大小 | 简写-Xms100M |
| -XX:NewSize=20M | 设置年轻代的大小 | |
| -XX:MaxNewSize=50M | 年轻代最大大小 | |
| -XX:OldSize=50M | 设置老年代大小 | |
| -XX:MetaspaceSize=50M | 设置方法区大小 | |
| -XX:MaxMetaspaceSize=50M | 方法区最大大小 | |
| -XX:+UseParallelGC | 使用UseParallelGC | 新生代,吞吐量优先 |
| -XX:+UseParallelOldGC | 使用UseParallelOldGC | 老年代,吞吐量优先 |
| -XX:+UseConcMarkSweepGC | 使用CMS | 老年代,停顿时间优先 |
| -XX:+UseG1GC | 使用G1GC | 新生代,老年代,停顿时间优先 |
| -XX:NewRatio | 新老生代的比值 | 比如-XX:Ratio=4,则表示新生代:老年代=1:4,也就是新生代占整个堆内存的1/5 |
| -XX:SurvivorRatio | 两个S区和Eden区的比值 | 比如-XX:SurvivorRatio=8,也就是(S0+S1):Eden=2:8,也就是一个S占整个新生代的1/10 |
| -XX:+HeapDumpOnOutOfMemoryError | 启动堆内存溢出打印 | 当JVM堆内存发生溢出时,也就是OOM,自动生成dump文件 |
| -XX:HeapDumpPath=heap.hprof | 指定堆内存溢出打印目录 | 表示在当前目录生成一个heap.hprof文件 |
| -XX:+PrintGCDetails -XX:+PrintGCTimeStamps -XX:+PrintGCDateStamps -Xloggc:g1-gc.log |
打印出GC日志 | 可以使用不同的垃圾收集器,对比查看GC情况 |
| -Xss128k | 设置每个线程的堆栈大小 | 经验值是3000-5000最佳 |
| -XX:MaxTenuringThreshold=6 | 提升年老代的最大临界值 | 默认值为15 |
| -XX:InitiatingHeapOccupancyPercent | 启动并发GC周期时堆内存使用占比 | G1之类的垃圾收集器用它来触发并发GC周期,基于整个堆的使用率,而不只是某一代内存的使用比.值为0则表示”一直执行GC循环”.默认值为45 |
| -XX:G1HeapWastePercent | 允许的浪费堆空间的占比 | 默认是10%,如果并发标记可回收的空间小于10%,则不会触发MixedGC。 |
| -XX:MaxGCPauseMillis=200ms | G1最大停顿时间 | 暂停时间不能太小,太小的话就会导致出现G1跟不上垃圾产生的速度。最终退化成FullGC。所以对这个参数的调优是一个持续的过程,逐步调整到最佳状态。 |
| -XX:ConcGCThreads=n | 并发垃圾收集器使用的线程数量 | 默认值随JVM运行的平台不同而不同 |
| -XX:G1MixedGCLiveThresholdPercent=65 | 混合垃圾回收周期中要包括的旧区 | 域设置占用率阈值默认占用率为65% |
| -XX:G1MixedGCCountTarget=8 | 设置标记周期完成后,对存活数据上限为G1MixedGCLIveThresholdPercent的旧区域执行混合垃圾回收的目标次数 | 默认8次混合垃圾回收,混合回收的目标是要控制在此目标次数以内 |
| -XX:G1OldCSetRegionThresholdPercent=1 | 描述Mixed GC时,OldRegion被加入到CSet中 | 默认情况下,G1只把10%的OldRegion加入到CSet中 |
四、设置参数的常见方式
1、开发工具:IDEA,eclipse
2、运行jar:java -XX:+UseG1GC xxx.jar
3、Web容器:tomcat脚本
4、通过jinfo实时调整某个java进程的参数(参数只有被标记为manageable的flags可以被实时修改)
版权声明
本文为[小仙。]所创,转载请带上原文链接,感谢
https://blog.csdn.net/weixin_43453386/article/details/124312289
边栏推荐
猜你喜欢

101. Symmetric Tree

"Gu Yu series" airdrop

Juc并发编程06——深入剖析队列同步器AQS源码

ARM调试(1):两种在keil中实现printf重定向到串口的方法

NEC红外遥控编码说明

Comparative analysis of meta universe from the dimension of knowledge dissemination

Epidemic prevention registration applet

工业元宇宙平台规划与建设

Windows安装redis并将redis设置成服务开机自启

一文看懂 LSTM(Long Short-Term Memory)
随机推荐
Go language practice mode - functional options pattern
一文看懂 LSTM(Long Short-Term Memory)
正大国际讲解道琼斯工业指数到底是什么?
工业元宇宙平台规划与建设
Ansible cloud computing automation
ansible 云计算 自动化 命令行精简版
Number theory blocking (integer division blocking)
[COCI] lattice (dichotomy + tree divide and conquer + string hash)
JUC concurrent programming 06 -- in-depth analysis of AQS source code of queue synchronizer
MapReduce核心和基础Demo
Juc并发编程07——公平锁真的公平吗(源码剖析)
第二章 In-Memory 体系结构 (IM-2.2)
Es aggregation aggregation analysis
元宇宙时代的职业规划与执行
2022年流动式起重机司机考试题库模拟考试平台操作
NEC红外遥控编码说明
雨生百谷,万物生长
Integral function and Dirichlet convolution
[codeforces - 208e] blood cousins
[lnoi2014] LCA - tree chain subdivision - multipoint LCA depth and problems