JVM参数使用小手册

最近复习了一下JVM,想小小的总结一下😄😄😄


标准参数

java  -version : 查看java版本号
java  -help	   : 快速查看帮助

-X参数

非标准参数,也就是在JDK各个版本中可能会变动

-Xint		:  解释执行
-Xcomp      :  第一次使用就编译成本地代码
-Xmixed     :  混合模式,JVM自己来决定

java -version
在这里插入图片描述
java -Xint -version
在这里插入图片描述
java -Xmixed -version
在这里插入图片描述


小插曲:编译型语言&解释型语言

编译型语言:直接将代码翻译成01的机器码,这个与操作系统有关。不同的操作系统翻译出来的机器码,是不一样的。编译型语言(编译之后的代码)不是跨平台的。
解释性语言:代码边执行边翻译,在不同的操作系统上,会将代码翻译成中间代码,然后再执行中间代码,所以执行效率不高。解释性语言是跨平台的。

通过-X参数,我们可以知道,java其实是一门混合的语言,java是先编译成字节码文件,然后再在jvm上解释执行。

推荐阅读
编译型语言&解释型语言一
编译型语言&解释型语言二
编译型语言&解释型语言三


-XX参数

使用得最多的参数类型
非标准化参数,相对不稳定,主要用于JVM调优和Debug

a.Boolean类型 格式:-XX:[+-]<name> +或-表示启用或者禁用name属性 
比如:
-XX:+UseConcMarkSweepGC 表示启用CMS类型的垃圾回收器 
-XX:+UseG1GC 表示启用G1类型的垃圾回收器 

b.非Boolean类型 格式:-XX<name>=<value>表示name属性的值是value 
比如:
-XX:MaxGCPauseMillis=500ms  表示G1最大停顿时间为500ms

-Xms1000M  等价于  -XX:InitialHeapSize=1000M 	表示:初始的堆内存为1000M
-Xmx1000M  等价于  -XX:MaxHeapSize=1000M 	    表示:最大的堆内存为1000M
-Xss100M   等价于  -XX:ThreadStackSize=100M	    表示:栈的内存为100M

查看参数

表示:将jvm的参数信息打印到flags.txt文件中
java -XX:+PrintFlagsFinal -version >flags.txt

在这里插入图片描述
然后将在C:\Users\Fenix 下面产生flags.txt文件(内容过多,只截图一部分)
在这里插入图片描述

1,值得注意的是"=“表示默认值,”:="表示被用户或JVM修改后的值
2,一般要设置参数,可以先查看一下当前参数是什么,然后进行修改


设置参数的方式

  • 开发工具中设置比如IDEA,eclipse
  • 运行jar包的时候:java -XX:+UseG1GC xxx.jar
  • web容器比如tomcat,可以在脚本中的进行设置
  • 通过jinfo实时调整某个java进程的参数(参数只有被标记为manageable的flags可以被实时修改)

参数小手册

参数含义说明
-XX:CICompilerCount=1最大并行编译数如果设置大于1,虽然编译速度会提高,但是同样影响系统稳定性,会增加 JVM崩溃的可能
-XX:InitialHeapSize=100M初始化堆大小简写-Xms100M
-XX:MaxHeapSize=100M最大堆大小简写-Xmx100M
-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: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=200msG1最大停顿时间暂停时间不能太小,太小的话就会导致出现G1跟不上垃圾产生的速度。最 终退化成Full GC。所以对这个参数的调优是一个持续的过程,逐步调整到 最佳状态。
-XX:ConcGCThreads=n并发垃圾收集器使用的线程数量默认值随JVM运行的平台不同而不同
-XX:G1MixedGCLiveThresholdPercent=65混合垃圾回收周期中要包括的旧区域设置占用率阈值默认占用率为 65%
-XX:G1MixedGCCountTarget=8设置标记周期完成后,对存活数据上限为 G1MixedGCLIveThresholdPercent 的旧区域执行混合 垃圾回收的目标次数默认8次混合垃圾回收,混合回收的目标是要控制在此目标次数以内
-XX:G1OldCSetRegionThresholdPercent=1描述Mixed GC时,Old Region被加入到CSet中默认情况下,G1只把10%的Old Region加入到CSet中

小插曲:-Xms与-Xmx的大小为什么要设置为相同大小

回顾

-Xms:表示堆内存的初始容量
-Xmx:表示堆内存的最大容量

为什么要设置为一样大小?

-Xms设置太大,JVM启动时分配内存失败,JVM崩溃。
-Xmx设置太大,Full GC后内存回收不理想,为了减少GC的频率,JVM向操作系统申请内存(但是这个个时候肯定是需要消耗系统资源的),直到达到最大容量,如果这个时候已经触发了Full GC还是装不下对象,那么就会导致OOM。我们需要注意如果在JVM向操作系统申请内存时,如果没有申请到那么就会到JVM崩溃。

Xms设置太大,JVM启动会崩。Xmx设的太大,JVM运行时会崩。

对于我而言在生产环境下,我觉得JVM启动的时候崩溃更能让我接受。生产环境意味着一台机器或者一个容器只有一个服务,独占机器意味着没有必要调整jvm大小,直接分配Xmx就行了,只有在开发环境,比如个人电脑,运行的进程特别多,jvm内存动态调整才可能有必要。

总之:Xms与Xmx设置相同大小的好处

  • 可以避免JVM向操作系统动态申请内存的时间开销
  • 延后启动后首次GC的发生时机
  • 减少启动初期的GC次数
  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值