写在前面
本文一起看下jvm启动参数相关内容,通过本文希望我自己也希望大家能够真正的应用到实际的工作中。
1:基本内容介绍
一般我们启动java程序有两种方式,一种是直接运行一个有main函数的class,第二种是运行一个在MANIFEST文件中指定了main类的jar包,格式分别如下:
class文件格式:
java [options] classname [args]
jar包格式:
java [options] jarfilename [args]
其中[options]就是我们本文要分析的jvm的参数配置,[args]是main函数的参数即main(String[] arags)中的args
参数具体可以分为标准参数,非标准参数,系统属性参数等,分别来看下。
- 标准参数
标准参数是以-
开头的参数,这种参数是所有的JVM都会实现和支持的,并且会一直兼容,如-server 设置jvm的运行模式。 - 系统属性参数
系统属性参数通过-D设置,如-Dfile.encoding=UTF-8,设置编码。 - 非标准参数
非标准参数通过 -X 设置,这种参数并不保证所有JVM的都支持,并且不保证向后兼容,如 -Xms2g -Xmx4g,可以通过java -X查看当前jvm支持非标准参数都有哪些,如下:
bogon:~ xb$ java -version
java version "9.0.4"
Java(TM) SE Runtime Environment (build 9.0.4+11)
Java HotSpot(TM) 64-Bit Server VM (build 9.0.4+11, mixed mode)
bogon:~ xb$ java -X
-Xbatch 禁用后台编译
-Xbootclasspath/a:<directories and zip/jar files separated by :>
附加在引导类路径末尾
-Xcheck:jni 对 JNI 函数执行其他检查
-Xcomp 在首次调用时强制编译方法
-Xdebug 为实现向后兼容而提供
-Xdiag 显示附加诊断消息
-Xfuture 启用最严格的检查, 预期将来的默认值
-Xint 仅解释模式执行
-Xinternalversion
显示比 -version 选项更详细的 JVM
版本信息
...
- 非稳定参数
非稳定参数通过-XX:
开头,其和具体的jvm有关,且随时可能随时在下一个版本中删除,具体使用在如下两种形式其中一种,如下:
-XX:+-flag
打开某布尔的开关,如-XX:+UseG1GC设置使用G1 GC。
-XX:key=value
通过kv的形式设置值,如-XX:MaxPermSize=256m,设置方法区大小为256m
2:参数分类
按照参数设置的内容可以分为如下6类,分别看下。
2.1:系统属性参数
系统属性参数首先我们可以在操作系统级别设置,如果是windows则是在如下界面设置:
如果是Linux则可以在/etc/profile
等文件中配置,但是这种方式配置的是全局的,对所有的进程生效,另外一种就是通过 -D:k=v 设置进程的属性,如-Dmaven.test.skip.true
,-Dfile.encoding=UTF-8
,当然也可以通过System.setProperty来设置,如下测试:
2.2:内存大小参数
为了方便对应到具体的内存区域,我们先来看下jvm的内存结构,如下图:
先看下主要参数:
-Xms
设置堆内存的初始大小,即最小内存
-Xmx
设置堆的最大大小,一般-Xms和-Xmx设置为一样,这样可以避免堆内存扩容带来的性能抖动
-Xms
设置堆的young区的大小
-XX:MaxDirectMemorySize=size
设置可以使用的最大堆外内存,即操作系统的内存,效果同-Dsun.nio.MaxDirectoryMemorySize=size
-Xss
设置线程栈的大小,影响栈的深度,如-Xss1m,即设置线程栈的大小为1M,效果同-XX:ThreadStackSize=size
这些参数和jvm内存结构关系如下图:
2.3:GC相关参数
主要是设置使用何种类型的垃圾收集器,如下:
-XX:+UseG1GC 使用G1垃圾收集器
-XX:+UseConcMarkSweepGC 使用CMS垃圾收集器
-XX:+UseSerialGC 使用串行垃圾收集器
-XX:+UseParallelGC 使用并行垃圾收集器
2.4:分析诊断相关相关参数
-XX:+HeapDumpOnOutOfMemoryError 当发生OutOfMemoryError时,自动dump堆内存
如,java -XX:+HeapDumpOnOutOfMemoryError -Xmx256m SomeJavaFile
-XX:+HeapDumpPath 与-XX:HeapDumpOnOutOfMemoryError 配合使用,设置发生了OOM后生成dump文件路径,如果是没有指定则默认为启动java程序的工作目录
如,java -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/usr/local -Xmx256m SomeJavaFile
-XX:OnOutOfMemoryError 抛出OutOfMemoryError错误时执行的脚本
-XX:ErrorFile=filename 致命错误的日志文件名称,绝对路径或者相对路径
2.5:javaagent
TODO 学习后补充!!!