JVM--各类参数详解及参数调优

JVM参数分类

JVM参数按照虚拟机来分,可以分为:
1、标准参数
2、非标准参数
3、非Stable参数

按参数功能来分,可以分为:
1、调优参数(线上环境调优必备)
2、行为参数
3、调试参数

标准参数

标准参数以 (-)开头:是所有JVM虚拟机都遵守和实现的参数,可通过命令行:java来查看,具体详情如下:

	-d32          使用 32 位数据模型 (如果可用)
    -d64          使用 64 位数据模型 (如果可用)
    -server       选择 "server" VM
                  默认 VM 是 server.

    -cp          <目录和 zip/jar 文件的类搜索路径>
    -classpath   <目录和 zip/jar 文件的类搜索路径>; 分隔的目录, JAR 档案
                  和 ZIP 档案列表, 用于搜索类文件。
    -D            <名称>=<>
                  设置系统属性
    -verbose:[class|gc|jni]
                  启用详细输出
    -version      输出产品版本并退出
    -version:        <>
                  警告: 此功能已过时, 将在
                  未来发行版中删除。
                  需要指定的版本才能运行
    -showversion  输出产品版本并继续
    -jre-restrict-search | -no-jre-restrict-search
                  警告: 此功能已过时, 将在
                  未来发行版中删除。
                  在版本搜索中包括/排除用户专用 JRE
    -? -help      输出此帮助消息
    -X            输出非标准选项的帮助
    -ea[:<packagename>...|:<classname>]
    -enableassertions[:<packagename>...|:<classname>]
                  按指定的粒度启用断言
    -da[:<packagename>...|:<classname>]
    -disableassertions[:<packagename>...|:<classname>]
                  禁用具有指定粒度的断言
    -esa | -enablesystemassertions
                  启用系统断言
    -dsa | -disablesystemassertions
                  禁用系统断言
    -agentlib:<libname>[=<选项>]
                  加载本机代理库 <libname>, 例如 -agentlib:hprof
                  另请参阅 -agentlib:jdwp=help 和 -agentlib:hprof=help
    -agentpath:<pathname>[=<选项>]
                  按完整路径名加载本机代理库
    -javaagent:<jarpath>[=<选项>]
                  加载 Java 编程语言代理, 请参阅 java.lang.instrument
    -splash:<imagepath>
                  使用指定的图像显示启动屏幕
非标准参数

非标准参数以(-X)开头,大部分JVM会默认实现,但是不保证所有的JVM都会实现,其中常用的有:

命令功能
-Xms设置初始 Java 堆大小
-Xmx设置最大 Java 堆大小
-Xss设置 Java 线程堆栈大小

通过命令行运行:java -X获取所有的非标准参数详细命令:

 	-Xmixed           混合模式执行 (默认)
    -Xint             仅解释模式执行
    -Xbootclasspath:<; 分隔的目录和 zip/jar 文件>
                      设置搜索路径以引导类和资源
    -Xbootclasspath/a:<; 分隔的目录和 zip/jar 文件>
                      附加在引导类路径末尾
    -Xbootclasspath/p:<; 分隔的目录和 zip/jar 文件>
                      置于引导类路径之前
    -Xdiag            显示附加诊断消息
    -Xnoclassgc       禁用类垃圾收集
    -Xincgc           启用增量垃圾收集
    -Xloggc:<file>    将 GC 状态记录在文件中 (带时间戳)
    -Xbatch           禁用后台编译
    -Xms<size>        设置初始 Java 堆大小
    -Xmx<size>        设置最大 Java 堆大小
    -Xss<size>        设置 Java 线程堆栈大小
    -Xprof            输出 cpu 配置文件数据
    -Xfuture          启用最严格的检查, 预期将来的默认值
    -Xrs              减少 Java/VM 对操作系统信号的使用 (请参阅文档)
    -Xcheck:jni       对 JNI 函数执行其他检查
    -Xshare:off       不尝试使用共享类数据
    -Xshare:auto      在可能的情况下使用共享类数据 (默认)
    -Xshare:on        要求使用共享类数据, 否则将失败。
    -XshowSettings    显示所有设置并继续
    -XshowSettings:all
                      显示所有设置并继续
    -XshowSettings:vm 显示所有与 vm 相关的设置并继续
    -XshowSettings:properties
                      显示所有属性设置并继续
    -XshowSettings:locale
                      显示所有与区域设置相关的设置并继续
非Stable参数

非Stable参数以(-XX)开头,这些参数对JVM参数调优非常有用。运行命令:java -XX:+PrintFlagsFinal 可以查看所有的非Stable参数。具体参数详情可参考官网说明
其中

=xxx表示默认值,未作修改
:=xxx表示用户做过自定义修改

在调优过程中:

  • 布尔类型参数通过**(+/-)**来设置开启或者关闭,例如:-XX:+<option>设置命令功能开启,-XX:-<option>设置命令功能关闭

  • 数字类型参数可通过-XX:<option>=<number>来设置,其中可通过数值单位mM表示兆字节,例如:-XX:<option>=32k-XX:<option>=32768等效。可用单位有:K、M、G等。

  • 字符串类型参数可通过-XX:<option>=<string>来设置,通常用于指定文件、路径、命令列表等。

下面列举一些常见的命令:

  • G1垃圾回收器参数
命令默认值说明
-XX:+UseG1GCtrue(默认开启)是否启用G1垃圾回收器,Hotspot虚拟机默认开启此功能
-XX:MaxGCPauseMillis=n200ms设置每次年轻代垃圾回收的最长时间,即如果年轻代中垃圾累计到一定数量,回收这些垃圾需要200ms,则不继续收集垃圾 先清理当前垃圾后再继续回收。如果无法满足此时间,JVM会自动调整年轻代大小,以满足此值。
-XX:InitiatingHeapOccupancyPercent=n45启动并发GC周期时的堆内存占用百分比。G1垃圾收集器用它来触发并发GC周期,基于整个堆内存的使用率,而不是某新生代或者老年代的使用率。值为 0 则表示"一直执行GC循环"。默认值为 45。
-XX:NewRatio=n2老年代与新生代的比例,默认值是2,即老年代:新生代=2:1
-XX:SurvivorRatio=n8eden/survivor(2个) 空间大小的比例(Ratio). 默认值为 8。即Eden:Survivor =8:2
-XX:MaxTenuringThreshold=n15从年轻代晋升到老年代的年龄阈值,表示对象在Survivor区经历多少次Young GC后晋升到年老代,也是和其他分代收集器一样的。默认值是:15
-XX:ParallelGCThreads=nGC在并行处理阶段多少个线程,此值最好配置与处理器数目相等。默认值和平台有关。
-XX:ConcGCThreads=n并发标记阶段的线程数量。默认值和平台有关。
-XX:G1ReservePercent=n10堆内存的预留空间百分比,用于降低晋升失败的风险。默认值是 10,即会将 10% 的堆内存预留下来。.
-XX:G1HeapRegionSize=nG1垃圾回收中,每一个region的大小,默认会根据堆内存的大小来自动计算分配,范围1M-32M
  • 性能调优参数
命令默认值说明
  • 开关参数
命令默认值说明
  • JVM调试参数
命令默认值说明
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值