[转]JVM参数使用手册
内存分配相关
Xms
英文释义:Initial heap size(in bytes)
中文释义:堆区初始值
使用方法:-Xms2g 或 -XX:InitialHeapSize=2048m
Xmx
英文释义:Maximum heap size(in bytes)
中文释义:堆区最大值
使用方法:-Xmx2g 或 -XX:MaxHeapSize=2048m
Xmn
英文释义:Maximum new generation size(in bytes)
中文释义:新生代最大值
使用方法:-Xmn512m 或 -XX:MaxNewSize=512m
PermSize、MetaspaceSize
英文释义:Initial size of permanent generation(in bytes)
中文释义:永久代(元空间)初始值
使用方法:-XX:PermSize=128m(1.7 之前版本)、-XX:MetaspaceSize=128m(1.7 之后版本)
MaxPermSize、MetaspaceSize
英文释义:Maximum size of permanent generation(in bytes)
中文释义:永久代(元空间)最大值
使用方法:-XX:MaxPermSize=256m(1.7之前版本)、-XX:MaxMetaspaceSize=256m(1.7之后版本)
Xss
英文释义:Thread Stack Size(in Kbytes)
中文释义:线程栈最大值
使用方法:-Xss256k 或 -XX:ThreadStackSize=256k
GC 策略相关
SurvivorRatio
英文释义:Rato of eden/survivor space size
中文释义:Eden 区和 Survivor 的比值
使用方法:-XX:SurvivorRatio=6
使用经验:默认值为 8,假如设为 6,则表示每个 Survivor 区跟 Eden 区的比值为1:6,每个 Survivor 区占新生代的八分之一
PretenureSizeThreshold
英文释义:Maximum size in bytes of objects allocated in DefNew generation;zero means no maximum
中文释义:可以在新生代直接分配的对象最大值,0表示没有最大值
使用方法:-XX:PretenureSizeThreshold=1000000
使用经验:设置该参数,可以使大于这个值的对象直接在老年代分配,避免在 Eden 区和 Survivor 区发生大量的内存复制,该参数只对 Serial 和 ParNew 收集器有效,Parallel Scavenge并不认识该参数
MaxTenuringThreshold
英文释义:Maximum value fo tenuring threshold
中文释义:新生代最大年龄
使用方法:-XX:MaxTenuringThreshold=10
使用经验:每个对象在坚持过一次Minor GC之后,年龄就增加1,当超过这个参数值时就进入老年代,最大支持15
ParallelGCThreads
英文释义:Number of parallel threads parallel gc will use
中文释义:并行执行gc的线程数
使用方法:-XX:ParallelGCThreads=16
UseSerialGC
英文释义:Use the Serial garbage collector
中文释义:新生代使用 Serial 垃圾收集器
使用方法:开启 -XX:+UseSerialGC、关闭 -XX:-UseSerialGC
使用经验:虚拟机在运行在 Client 模式下的默认值,老年代将会使用 SerialOld 垃圾收集器
UseParNewGC
英文释义:Use parallel threads in the new generation
中文释义:新生代使用 ParNew 垃圾收集器
使用方法:开启 -XX:+UseParNewGC、关闭 -XX:-UseParNewGC
使用经验:老年代将使用 Serial Old 收集器
CMSParallelRemarkEnabled
英文释义:Whether parallel remark enabled (only if ParNewGC)
中文释义:是否启用并行标记(仅限于ParNewGC)
使用方法:开启 -XX:+CMSParallelRemarkEnabled、关闭 -XX:-CMSParallelRemarkEnabled
UseParallelGC
英文释义:Use the Parallel Scavenge garbage collector
中文释义:新生代使用 Parallel Scavenge 垃圾收集器
使用方法:开启 -XX:+UseParallelGC、关闭 -XX:-UseParallelGC
使用经验:Linux下1.6,1.7,1.8 默认开启(1.9 后默认启用 G1 收集器),老年代将会使用 Serial Old 垃圾收集器
UseAdaptiveSizePolicy
英文释义:Use adaptive generation sizing policies
中文释义:自适应调节策略,动态调整 Java 堆中各个区域的大小以及进入老年代的年龄
使用方法:开启 -XX:+UseAdaptiveSizePolicy、关闭 -XX:-UseAdaptiveSizePolicy
MaxTimeRatio
英文释义:
中文释义:GC 时间占总时间的比率,默认值为 99,即允许 1% 的 GC 时间。仅在 Parallel Scavenge 收集器时生效。
使用方法:-XX:MaxTimeRatio=99
MaxGCPauseMillis
英文释义:Adaptive size policy maximum GC pause time goal in millisecond, or (G1 Only) the maximum GC time per MMU time slice
中文释义:自适应策略的最大GC暂停时间目标(以毫秒为单位),或(仅G1)每个MMU时间片的最大GC时间
使用方法:-XX:MaxGCPauseMillis=200
UseParallelOldGC
英文释义:Use the Parallel Old garbage collector
中文释义:老年代使用 Parallel Old 收集器
使用方法:开启 -XX:+UseParallelOldGC、关闭 -XX:-UseParallelOldGC
使用经验:新生代将使用 Parallel Scavenge 收集器
UseConcMarkSweepGC
英文释义:Use Concurrent Mark-Sweep GC in the old generation
中文释义:老年代使用 CMS 收集器
使用方法:开启 -XX:+UseConcMarkSweepGC、关闭 -XX:-UseConcMarkSweepGC
使用经验:年轻代将会使用 ParNew 收集器,如果出现"Concurrent Mode Failure",会使用 Serial Old 收集器
CMSInitiatingOccupancyFraction
英文释义:Percentage CMS generation occupancy to start a CMS collection cycle. A negative value means that CMSTriggerRatio is used
中文释义:触发执行 CMS 回收的老年代内存空间占用的百分比,负值表示使用 CMSTriggerRatio 设置的值
使用方法:-XX:+CMSInitiatingOccupancyFraction=75
UseCMSInitiatingOccupancyOnly
英文释义:Only use occupancy as a criterion for staring a CMS collection
中文释义:只根据占用情况作为开始执行CMS收集的标准
使用方法:开启 -XX:+UseCMSInitiatingOccupancyOnly、关闭 -XX:-UseCMSInitiatingOccupancyOnly
UseCMSCompactAtFullCollection
英文释义:Use Mark-Sweep-Compact algorithm at full collections
中文释义:设置 CMS 收集器在完成垃圾收集后是否要进行一次碎片整理
使用方法:开启 -XX:+UseCMSCompactAtFullCollection、关闭 -XX:-UseCMSCompactAtFullCollection
CMSFullGCsBeforeCompaction
英文释义:Number of CMS full collection done before compaction if > 0
中文释义:设置 CMS 收集器在进行若干次垃圾收集后再启动一次内存碎片整理。
使用方法:-XX:CMSFullGCsBeforeCompaction=1
CMSClassUnloadingEnabled
英文释义:Whether class unloading enabled when using CMS GC
中文释义:当使用CMS GC时是否启用类卸载功能
使用方法:开启 -XX:+CMSClassUnloadingEnabled、关闭 -XX:-CMSClassUnloadingEnabled
UseG1GC
英文释义:Use the Garbage-First garbage collector
中文释义:使用G1垃圾收集器
使用方法:开启 -XX:+UseG1GC、关闭 -XX:-UseG1GC
使用经验:JDK 1.9 后默认选择的垃圾收集器
DisableExplicitGC
英文释义:Ignore calls to System.gc()
中文释义:禁用 System.gc() 触发FullGC
使用方法:开启 -XX:+DisableExplicitGC、关闭 -XX:-DisableExplicitGC
使用经验:不建议开启,如果开启了这个参数可能会导致对外内存无法及时回收造成对外内存溢出
GC日志相关
Xloggc
英文释义:GC log file
中文释义:GC日志文件路径
使用方法:-Xloggc:/data/gclog/gc.log
UseGCLogFileRotation
英文释义:Rotate gclog files(for long running applications). It requires -Xloggc:
中文释义:滚动GC日志文件,须配置Xloggc
使用方法:开启 -XX:+UseGCLogFileRotation、关闭 -XX:-UseGCLogFileRotation
NumberOfGCLogFiles
英文释义:Number of gclog files in rotation(default:0,no rotation)
中文释义:滚动 GC日志文件数,默认0,不滚动
使用方法:-XX:NumberOfGCLogFiles=4
GCLogFileSize
英文释义:GC log file size,requires UseGCLogFileRotation. Set to 0 to only trigger rotation via jcmd
中文释义:GC文件滚动大小,需配置UseGCLogFileRotation,设置为0表示仅通过jcmd命令触发
使用方法:-XX:GCLogFileSize=100k
PrintGCDetails
英文释义:Print more details at garbage collection
中文释义:GC时打印更多详细信息
使用方法:开启 -XX:+PrintGCDetails、关闭 -XX:-PrintGCDetails
使用经验:可以通过jinfo -flag [+|-]PrintGCDetails 或 jinfo -flag PrintGCDetails= 来动态开启或设置值
PrintGCDateStamps
英文释义:Print date stamps at garbage collection
中文释义:GC时打印时间戳信息
使用方法:开启 -XX:+PrintGCDateStamps、关闭 -XX:-PrintGCDateStamps
使用经验:可以通过jinfo -flag [+|-] PrintGCDateStamps 或 jinfo -flag PrintGCDateStamps= 来动态开启或设置值
PrintTenuringDistribution
英文释义:Print tenuring age information
中文释义:打印存活实例年龄信息
使用方法:开启 -XX:+PrintTenuringDistribution、关闭 -XX:-PrintTenuringDistribution
PrintGCApplicationStoppedTime
英文释义:Print the time of application has been stopped
中文释义:打印应用暂停时间
使用方法:开启 -XX:+PrintGCApplicationStoppedTime、关闭 -XX:-PrintGCApplicationStoppedTime
PrintHeapAtGC
英文释义:Print heap layout before and after each GC
中文释义:GC前后打印堆区使用信息
使用方法:开启 -XX:+PrintHeapAtGC、关闭 -XX:-PrintHeapAtGC
异常相关
HeapDumpOnOutOfMemoryError
英文释义:Dump heap to file when java.lang.OutOfMemoryError is thrown
中文释义:抛出内存溢出错误时导出堆信息到指定文件
使用方法:开启 -XX:+HeapDumpOnOutOfMemoryError、关闭 -XX:-HeapDumpOnOutOfMemoryError
使用经验:可以通过 jinfo -flag [+|-]HeapDumpOnOutOfMemoryError 或 jinfo -flag HeapDumpOnOutOfMemoryError= 来动态开启或设置值
HeapDumpPath
英文释义:When HeapDumpOnOutOfMemoryError is on, the path(filename or directory) of the dump file(defaults to java_pid.hprof in the working directory)
中文释义:当 HeapDumpOnOutOfMemoryError 开启的时候,dump 文件的保存路径,默认为工作目录下的 java_pid.hprof 文件
使用方法:-XX:HeapDumpPath=/data/dump/jvm.dump
其他
server
英文释义:server mode
中文释义:服务端模式
使用方法:-server
TieredCompilation
英文释义:Enable tiered compilation
中文释义:启用多层编译
使用方法:开启 -XX:+TieredCompilation、关闭 -XX:-TieredCompilation
原文链接:https://segmentfault.com/a/1190000010603813
[转]JVM参数使用手册的更多相关文章
- Java 6 JVM参数选项大全(中文版)
原文来自: http://kenwublog.com/docs/java6-jvm-options-chinese-edition.htm 本文是基于最新的SUN官方文档Java SE 6 Hotsp ...
- jinfo_动态调整JVM参数(无需重启)(实践)
本文演示在JVM进程运行过程中动态开启/关闭 GC输出,无需重启JVM进程 jinfo使用介绍 可以用来查看正在运行的Java应用程序的扩展参数,甚至支持在运行时,修改部分参数 -flag < ...
- JVM参数OmitStackTraceInFastThrow:不打印NullPointerException异常堆栈
查看线上日志,遇到一个诡异的问题,就是系统大量空指针的异常,但是没有打印堆栈,导致不方便定位问题. 经过一番代码调试,确定并非程序代码问题.没有线索之后,从Google找到了答案:是因为在server ...
- tomcat,zookeeper,activeMQ,Kafka设置jvm参数
1,tomcat设置jvm参数 设置方法: 在tomcat bin 目录增加配置:setenv.sh #add tomcat pid CATALINA_PID="$CATALINA_ ...
- JVM参数调优
JVM参数调优 JVM参数调优是一个很头痛的问题,可能和应用有关系,下面是本人一些调优的实践经验,希望对读者能有帮助,环境LinuxAS4,resin2.1.17,JDK6.0,2CPU,4G内存,d ...
- Scala命令设置JVM参数的规则
Scala下设置JVM参数简单分析 Scala 启动shell脚本,简化后的scala REPL 启动命令大致如下所示: java -Xmx256M -Xms32M \-Xbootclasspath/ ...
- JVM参数设置、分析(转发)
JVM参数的含义 实例见实例分析 参数名称 含义 默认值 -Xms 初始堆大小 物理内存的1/64(<1GB) 默认(MinHeapFreeRatio参数可以调整)空余堆内存小于40%时,J ...
- JVM参数(二)参数分类和即时(JIT)编译器诊断
在这个系列的第二部分,我来介绍一下HotSpot JVM提供的不同类别的参数.我同样会讨论一些关于JIT编译器诊断的有趣参数. JVM 参数分类 HotSpot JVM 提供了三类参数.第一类包括了标 ...
- JVM参数(三)打印所有XX参数及值
本篇文章基于Java 6(update 21oder 21之后)版本, HotSpot JVM 提供给了两个新的参数,在JVM启动后,在命令行中可以输出所有XX参数和值. -XX:+PrintFlag ...
随机推荐
- SpringMvc demo示例及源码详细分析
三层架构介绍 我们的开发架构一般都是基于两种形式,一种C/S架构,也就是客户端/服务器,另一种是B/S架构,也就是浏览器/服务器.在JavaEE开发中,几乎全部都是基于B/S架构的开发.那么在B/S架 ...
- 微信小程序使用 ECharts 实现数据可视化
微信小程序使用 ECharts 显示图表 首先创建微信小程序 这里就不再赘述 下载 GitHub 上的 ecomfe/echarts-for-weixin 下载后解压,打开文件夹,里面的 ec-can ...
- 公众号在线Markdown编辑器,支持公式
公众号排版不支持Markdown,用自带的富文本编辑器排版出来的格式十分丑陋,尤其是公式,竟然连"Mathjax"都不支持,但好在支持"带格式复制",也即可以将 ...
- 利用keytool、openssl生成证书文件
转载请标明出处:http://blog.csdn.net/shensky711/article/details/52225073 本文出自: [HansChen的博客] 用openssl指令逐步生成各 ...
- 当linux突然修改任何设置都没办法联网时的绝对有效解决办法
以下操作为重新启动虚拟网卡的相关配置,初始化并重启虚拟网卡,对目前的配置不会有任何影响 打开终端,依次输入以下内容:– sudo service network-manager stop– sudo ...
- Linux(CentOS7)修改默认yum源为国内的阿里云、网易yum源
修改方式: echo 备份当前的yum源 mv /etc/yum.repos.d /etc/yum.repos.d.backup4comex echo 新建空的yum源设置目录 mkdir /etc/ ...
- 使用Python爬取、清洗并分析前程无忧的大数据职位
爬取前程无忧的数据(大数据职位) # -*- coding: utf-8 -*- """ Created on Wed Nov 1 14:47:27 2019 @auth ...
- 深入理解inode和硬链接和软连接和挂载点
inode 一.inode是什么? 理解inode,要从文件储存说起. 扇区 文件储存在硬盘上,硬盘的最小存储单位叫做"扇区"(Sector).每个扇区储存512字节(相当于0.5 ...
- go变量
go基础 go变量(静态) package main import "fmt" func main() { //申明变量 var zx int //变量赋值 zx=10 //输出变 ...
- C语言博客作业08
C语言I博客作业08](https://www.cnblogs.com/490-85-00-58-/p/11863312.html) 问题 回答 这个作业属于那个课程 C语言程序设计II 这个作业要求 ...