【JVM参数汇总】

jvm的参数分为三类:

1. 标准参数(-) 所有的JVM实现都必须实现这些参数的功能,而且向后兼容。

例:-help -version

2. 非标准参数(-X) 默认jvm实现这些参数的功能,但是并不保证所有jvm实现都满足,且不保证向后兼容

例:-Xint 解析模式运行,启动很快,执行稍慢;-Xcomp 纯编译模式运行,执行很快,启动很慢;

-Xmixed 混合模式,开始解释执行,启动速度较快,对热点代码实行检 测和编译。默认此模式

3.非Stable参数(-XX) 各个jvm实现会有所不同,将来可能会随时取消,需要慎重使用

例:-XX:newSize ;-XX:+UseG1GC

JVM种中常见非标准参数以及一些解释:

a.(-X)参数

   -Xms       设置初始 Java 堆大小   (比较重要) 

   -Xmx       设置最大 Java 堆大小    (比较重要) 线上通常最大java堆大小与初始堆大小设置为一样大,默认为服务器内存的四分之一,32G服务器调优时 通常设置为12G

   -Xss       设置 Java 线程堆栈大小  (比较重要) 

   -Xmixed           混合模式执行 

   -Xint             仅解释模式执行 

   -Xbootclasspath:用 : 分隔的目录和 zip/jar 文件>                     设置搜索路径以引导类和资源

   -Xbootclasspath/a:用 : 分隔的目录和 zip/jar 文件>                     附加在引导类路径末尾

   -Xbootclasspath/p:用 : 分隔的目录和 zip/jar 文件>                     置于引导类路径之前

   -Xdiag           显示附加诊断消息

   -Xnoclassgc       禁用类垃圾收集

   -Xincgc           启用增量垃圾收集

   -Xloggc:   将 GC 状态记录在文件中 (带时间戳)    -Xbatch           禁用后台编译  

   -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                     显示所有与区域设置相关的设置并继续

b.(-XX)参数

   (1)行为参数(功能开关)

        -XX:-DisableExplicitGC 禁止调用System.gc();但jvm的gc仍然有效

        -XX:+MaxFDLimit 最大化文件描述符的数量限制

        -XX:+ScavengeBeforeFullGC   新生代GC优先于Full GC执行

        -XX:+UseGCOverheadLimit 在抛出OOM之前限制jvm耗费在GC上的时间比例

        -XX:-UseConcMarkSweepGC 对老生代采用并发标记交换算法进行GC

        -XX:-UseParallelGC 启用并行GC

        -XX:-UseParallelOldGC   对Full GC启用并行,当-XX:-UseParallelGC

启用时该项自动启用

        -XX:-UseSerialGC   启用串行GC

        -XX:+UseThreadPriorities   启用本地线程优先级

 (2)性能调优

        -XX:LargePageSizeInBytes=4m 设置用于Java堆的大页面尺寸

        -XX:MaxHeapFreeRatio=70 GC后java堆中空闲量占的最大比例

        -XX:MaxNewSize=size 新生成对象能占用内存的最大值

        -XX:MaxPermSize=64m 老生代对象能占用内存的最大值

        -XX:MinHeapFreeRatio=40 GC后java堆中空闲量占的最小比例

        -XX:NewRatio=2 新生代内存容量与老生代内存容量的比例

        -XX:NewSize=2.125m 新生代对象生成时占用内存的默认值

        -XX:ReservedCodeCacheSize=32m   保留代码占用的内存容量

        -XX:ThreadStackSize=512 设置线程栈大小,若为0则使用系统默认值

        -XX:+UseLargePages 使用大页面内存

 (3)调试参数

        -XX:-CITime 打印消耗在JIT编译的时间

        -XX:ErrorFile=./hs_err_pid.log 保存错误日志或者数据到文件中

        -XX:-ExtendedDTraceProbes   开启solaris特有的dtrace探针

        -XX:HeapDumpPath=./java_pid.hprof 指定导出堆信息时的路径或 文件名

        -XX:-HeapDumpOnOutOfMemoryError 当首次遭遇OOM时导出此时堆中相关信息

        -XX:OnError=";" 出现致命ERROR之后运行自定义命令

        -XX:OnOutOfMemoryError=";" 当首次遭遇OOM时 执行自定义命令

        -XX:-PrintClassHistogram   遇到Ctrl-Break后打印类实例的柱状信 息,与jmap -histo功能相同

        -XX:-PrintConcurrentLocks   遇到Ctrl-Break后打印并发锁的相关信 息,与jstack -l功能相同

        -XX:-PrintCommandLineFlags 打印在命令行中出现过的标记

        -XX:-PrintCompilation   当一个方法被编译时打印相关信息

        -XX:-PrintGC   每次GC时打印相关信息

        -XX:-PrintGCDetails   每次GC时打印详细信息

        -XX:-PrintGCTimeStamps 打印每次GC的时间戳

        -XX:-TraceClassLoading 跟踪类的加载信息

        -XX:-TraceClassLoadingPreorder 跟踪被引用到的所有类的加载信息

        -XX:-TraceClassResolution   跟踪常量池

        -XX:-TraceClassUnloading   跟踪类的卸载信息

        -XX:-TraceLoaderConstraints 跟踪类加载器约束的相关信息

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值