[转]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 ...
随机推荐
- [FPGA]浅谈LCD1602字符型液晶显示器(Verilog)
目录 概述 LCD1602 LCD1602是什么? LCD1602的管脚 RS_数据/命令选择 E_使能 D0-D7 LCD1602有个DDRAM LCD1602还有个CGROM 指令集 清屏 进入模 ...
- salesforce lightning零基础学习(十五) 公用组件之 获取表字段的Picklist(多语言)
此篇参考:salesforce 零基础学习(六十二)获取sObject中类型为Picklist的field values(含record type) 我们在lightning中在前台会经常碰到获取pi ...
- Android官方提供的支持不同屏幕大小的全部方法(转)
转载请注明出处:http://blog.csdn.net/guolin_blog/article/details/8830286 原文地址为:http://developer.android.com/ ...
- Lab4\5:进程和线程
进程的定义 进程是指一个具有一定独立功能的程序在一个数据集合上的一次动态执行过程 源代码在经过编译链接之后生成了可执行文件,再由操作系统进行加载并且进行一些堆栈的分配才是进程 进程控制块 操作系统管理 ...
- day 17 re模块 正则表达式
import re 引用re模块 查找 finall:匹配所有,每一项都是列表中的一个元素 search:只匹配从左到右的第一个,得到的不是直接的结果而是一个变量,通过group方法获取结果,没 ...
- 【Android - 进阶】之Animation补间动画
补间动画也叫View动画,它只能针对View进行动画操作,且补间动画操作的只是View中可见的部分,即只操作界面,对于可点击区域等都不会进行操作. 在Android中,补间动画的顶级类是Animati ...
- react新版本配置代理
新学习react 开始配置react跨域的时候 在网上查看到是在packjson.json里面添加如下代码: "proxy": { "/api": { &quo ...
- 转载:不是书评 :《我是一只IT小小鸟》
本文转载自刘未鹏博客:http://www.mindhacks.cn. 原文地址如下:http://mindhacks.cn/2009/10/05/im-a-tiny-bird-book-review ...
- 大型情感剧集Selenium:3_元素定位 #华为云·寻找黑马程序员#
关于昨天的文章 今天有朋友反馈,代码运行的时候,selenium提示警告 DeprecationWarning: use options instead of chrome_options drive ...
- JQuery之选择集过滤
JQuery选择集过滤应用如下: 代码实现: <script src="JS/jquery-3.4.1.js"></script> <script&g ...