前言
所谓JVM的调优,其实就是修改JVM的各项参数,形成当前业务场景下最优配置。既然要调优,肯定要熟知JVM的各项参数代表的含义,本文主要是用来记录JVM的各个参数含义,方便以后调优时查阅。
JVM参数主要分为三类
1.标准参数
标准参数(-),所有的JVM实现都必须实现这些参数的功能,而且向后兼容, 通过命令 java即可查看。
image.png
用法: java [-options] class [args...]
(执行类)
或 java [-options] -jar jarfile [args...]
(执行 jar 文件)
其中选项包括:
-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>
使用指定的图像显示启动屏幕
有关详细信息, 请参阅 http://www.oracle.com/technetwork/java/javase/documentation/index.html。
2 非标准参数(-X)
默认jvm实现要实现这些参数的功能,但是并不保证所有jvm实现都满足这些参数功能,且不保证向后兼容, 通过命令 java -X可查看
image.png
-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
显示所有与区域设置相关的设置并继续
-X 选项是非标准选项, 如有更改, 恕不另行通知。
3.非稳定参数(-XX)
这些参数各个jvm实现会有所不同,并且可能会随时取消,需要慎重使用(注意:这些参数也是JVM调优的重要参数).
3.1)java -XX:+PrintFlagsInitial --查看出厂默认值
3.2)java -XX:+PrintFlagsFinal --查看修改更新 (= 没有修改过 := 人为修改过)
image.png
打印的结果就不在文章中展示了(700多项参数 x_x),下面会以JDK1.8为例慢慢更新-XX常用的调优参数,欢迎大家收藏使用。
-XX参数分为两大类,设置方式分别为:
1). Boolean类型:-XX:+/- (+代表开启,-代表关闭) 例如 -XX:+PrintGCDetails
2).数值型: -XX:[key]=[val] 例如–XX:NewRatio=2
-XX:SurvivorRatio=8 新生代Eden区和Survivor区的比例,默认8
–XX:NewRatio=2 老年代与新生代的比例,默认2
-XX:InitialHeapSize=134217728 设置初始堆大小
-XX:MaxHeapSize=2147483648 设置最大堆大小
-XX:MetaspaceSize=21807104 设置元空间大小
-XX:MaxMetaspaceSize=21807104 设置最大元空间大小
-XX:+PrintGCDetails 开启打印 GC 收集细节,一般跟 -Xloggc:<file> 配合使用(默认不开启)
-XX:+HeapDumpOnOutOfMemoryError 内存溢出时生成dump文件(默认不开启)
-XX:HeapDumpPath=/pathA/pathB.. 内存溢出时生成的文件路径
-XX:+UseParNewGC 使用ParNew作为新生代垃圾回收器
-XX:+UseConcMarkSweepGC 使用CMS作为老年代垃圾回收器
-XX:+UseCMSCompactAtFullCollection CMS发生FullGC时是否整理碎片 默认开启
-XX:+UseParallelGC 使用Parallel Scavenge作为新生代垃圾回收器
-XX:+UseParallelOldGC 使用Parallel Old作为老年代垃圾回收器
-XX:MaxTenuringThreshold=15 最大分代年龄 默认15(注意分代年龄占4字节,最大只能设置15)
-XX:+UseTLAB 优先在ThreadLocalAllocBuffer分配对象 默认开启
-XX:+UseBiasedLocking 开启偏向锁 默认开启
-XX:BiasedLockingStartupDelay=4000 延迟4秒开启 默认值
======未完待续=======