内存分配相关

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

PermSizeMetaspaceSize
英文释义:Initial size of permanent generation(in bytes)
中文释义:永久代(元空间)初始值
使用方法:-XX:PermSize=128m(1.7 之前版本)、-XX:MetaspaceSize=128m(1.7 之后版本)

MaxPermSizeMetaspaceSize
英文释义: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参数使用手册的更多相关文章

  1. Java 6 JVM参数选项大全(中文版)

    原文来自: http://kenwublog.com/docs/java6-jvm-options-chinese-edition.htm 本文是基于最新的SUN官方文档Java SE 6 Hotsp ...

  2. jinfo_动态调整JVM参数(无需重启)(实践)

    ​本文演示在JVM进程运行过程中动态开启/关闭 GC输出,无需重启JVM进程 jinfo使用介绍 可以用来查看正在运行的Java应用程序的扩展参数,甚至支持在运行时,修改部分参数 -flag < ...

  3. JVM参数OmitStackTraceInFastThrow:不打印NullPointerException异常堆栈

    查看线上日志,遇到一个诡异的问题,就是系统大量空指针的异常,但是没有打印堆栈,导致不方便定位问题. 经过一番代码调试,确定并非程序代码问题.没有线索之后,从Google找到了答案:是因为在server ...

  4. tomcat,zookeeper,activeMQ,Kafka设置jvm参数

    1,tomcat设置jvm参数 设置方法:   在tomcat bin 目录增加配置:setenv.sh   #add tomcat pid CATALINA_PID="$CATALINA_ ...

  5. JVM参数调优

    JVM参数调优 JVM参数调优是一个很头痛的问题,可能和应用有关系,下面是本人一些调优的实践经验,希望对读者能有帮助,环境LinuxAS4,resin2.1.17,JDK6.0,2CPU,4G内存,d ...

  6. Scala命令设置JVM参数的规则

    Scala下设置JVM参数简单分析 Scala 启动shell脚本,简化后的scala REPL 启动命令大致如下所示: java -Xmx256M -Xms32M \-Xbootclasspath/ ...

  7. JVM参数设置、分析(转发)

    JVM参数的含义 实例见实例分析 参数名称 含义 默认值   -Xms 初始堆大小 物理内存的1/64(<1GB) 默认(MinHeapFreeRatio参数可以调整)空余堆内存小于40%时,J ...

  8. JVM参数(二)参数分类和即时(JIT)编译器诊断

    在这个系列的第二部分,我来介绍一下HotSpot JVM提供的不同类别的参数.我同样会讨论一些关于JIT编译器诊断的有趣参数. JVM 参数分类 HotSpot JVM 提供了三类参数.第一类包括了标 ...

  9. JVM参数(三)打印所有XX参数及值

    本篇文章基于Java 6(update 21oder 21之后)版本, HotSpot JVM 提供给了两个新的参数,在JVM启动后,在命令行中可以输出所有XX参数和值. -XX:+PrintFlag ...

随机推荐

  1. 部署k8s集群监控Heapster

    git clone https://github.com/kubernetes/heapster.gitkubectl apply -f heapster/deploy/kube-config/inf ...

  2. 程序员用于机器学习编程的Python 数据处理库 pandas 入门教程

    入门介绍 pandas适合于许多不同类型的数据,包括: · 具有异构类型列的表格数据,例如SQL表格或Excel数据 · 有序和无序(不一定是固定频率)时间序列数据. · 具有行列标签的任意矩阵数据( ...

  3. 【Luogu P1878】舞蹈课

    Luogu P1878 事实上这道题并不难,但我真没弄懂我手写堆为什么过不了.所以 STL大法好!!! 基本思路 对于每一对相邻异性,将他们的舞蹈技术的差插入一个堆 通过维护这个小根堆,每次就可以取得 ...

  4. 【记录】洛谷P1739-表达式括号匹配AC记

    题面请查看:https://www.luogu.org/problem/P1739 思路: 见到括号就搜索,搜到与它配对的括号为止,搜不到就输出NO 代码: #include <bits/std ...

  5. just_connect.py

    # -*- coding=utf-8 -*-from mysql.connector import connect config = { 'host': '192.168.199.139', 'por ...

  6. scrapy的一个简单小项目

    使用scrapy抓取目标url下所有的课程名和价格,并将数据保存为json格式url=http://www.tanzhouedu.com/mall/course/initAllCourse 观察网页并 ...

  7. CSS新特性之2D转换transform

    transform是css3中具有颠覆性特征之一,可以实现元素的位移.旋转.缩放等效果 1.位移translate 1.1语法 transform: translate(x,y);//x,y分别表示x ...

  8. SpringBoot 整合mongoDB并自定义连接池

    SpringBoot 整合mongoDB并自定义连接池 得力于SpringBoot的特性,整合mongoDB是很容易的,我们整合mongoDB的目的就是想用它给我们提供的mongoTemplate,它 ...

  9. 07-kubernetes Ingress 原理 和 Ingress-nginx 案例

    目录 Service 类型 namespace 名称空间 Ingress Controller Ingress Ingress-nginx 进行测试 创建对应的后端Pod和Service 创建 Ing ...

  10. Kafka 0.10.0.1 consumer get earliest partition offset from Kafka broker cluster - scala code

    Return: Map[TopicPartition, Long] Code: val props = new Properties() props.put(ConsumerConfig.BOOTST ...