Java 6 JVM参数选项大全(中文版)
2010-04-13 22:53
281 查看
Java 6 JVM参数选项大全(中文版)
作者:Ken WuEmail: ken.wug@gmail.com
转载本文档请注明原文链接 http://kenwublog.com/docs/java6-jvm-options-chinese-edition.htm!
本文是基于最新的SUN官方文档Java SE 6 Hotspot VM Options 编写的译文。主要介绍JVM中的非稳态选项及其使用说明。
为了让读者明白每个选项的含义,作者在原文基础上补充了大量的资料。希望这份文档,对正在研究JVM参数的朋友有帮助!
另外,考虑到本文档是初稿,如有描述错误,敬请指正。
非稳态选项使用说明
-XX:+<option> 启用选项
-XX:-<option> 不启用选项
-XX:<option>=<number> 给选项设置一个数字类型值,可跟单位,例如 32k, 1024m, 2g
-XX:<option>=<string> 给选项设置一个字符串值,例如-XX:HeapDumpPath=./dump.core
行为选项
选项 | 默认值与限制 | 描述 |
-XX:-AllowUserSignalHandlers | 限于Linux和Solaris,默认不启用 | 允许为java进程安装信号处理器。 Java信号处理相关知识,详见 http://kenwublog.com/java-asynchronous-notify-based-on-signal |
-XX:-DisableExplicitGC | 默认不启用 | 禁止在运行期显式地调用 System.gc()。 开启该选项后,GC的触发时机将由Garbage Collector全权掌控。 注意:你熟悉的代码里没调用System.gc(),不代表你依赖的框架工具没在使用。 例如RMI就在多数用户毫不知情的情况下,显示地调用GC来防止自身OOM。 请仔细权衡禁用带来的影响。 |
-XX:-RelaxAccessControlCheck | 默认不启用 | 在Class校验器中,放松对访问控制的检查。 作用与reflection里的setAccessible类似。 |
-XX:-UseConcMarkSweepGC | 默认不启用 | 启用CMS低停顿垃圾收集器。 资料详见:http://kenwublog.com/docs/CMS_GC.pdf |
-XX:-UseParallelGC | -server时启用 其他情况下,默认不启用 | 策略为新生代使用并行清除,年老代使用单线程Mark-Sweep-Compact的垃圾收集器。 |
-XX:-UseParallelOldGC | 默认不启用 | 策略为老年代和新生代都使用并行清除的垃圾收集器。 |
-XX:-UseSerialGC | -client时启用 其他情况下,默认不启用 | 使用串行垃圾收集器。 |
-XX:+UseSplitVerifier | java5默认不启用 java6默认启用 | 使用新的Class类型校验器 。 新Class类型校验器有什么特点? 新Class类型校验器,将老的校验步骤拆分成了两步: 1,类型推断。 2,类型校验。 新类型校验器通过在javac编译时嵌入类型信息到bytecode中,省略了类型推断这一步,从而提升了classloader的性能。 Classload顺序(供参考) load -> verify -> prepare -> resove -> init 关联选项: -XX:+FailOverToOldVerifier |
-XX:+FailOverToOldVerifier | Java6新引入选项,默认启用 | 如果新的Class校验器检查失败,则使用老的校验器。 为什么会失败? 因为JDK6最高向下兼容到JDK1.2,而JDK1.2的class info 与JDK6的info存在较大的差异,所以新校验器可能会出现校验失败的情况。 关联选项: -XX:+UseSplitVerifier |
-XX:+HandlePromotionFailure | java5以前是默认不启用,java6默认启用 | 关闭新生代收集担保。 什么是新生代收集担保? 在一次理想化的minor gc中,Eden和First Survivor中的活跃对象会被复制到Second Survivor。 然而,Second Survivor不一定能容纳下所有从E和F区copy过来的活跃对象。 为了确保minor gc能够顺利完成,GC需要在年老代中额外保留一块足以容纳所有活跃对象的内存空间。 这个预留操作,就被称之为新生代收集担保(New Generation Guarantee)。如果预留操作无法完成时,仍会触发major gc(full gc)。 为什么要关闭新生代收集担保? 因为在年老代中预留的空间大小,是无法精确计算的。 为了确保极端情况的发生,GC参考了最坏情况下的新生代内存占用,即Eden+First Survivor。 这种策略无疑是在浪费年老代内存,从时序角度看,还会提前触发Full GC。 为了避免如上情况的发生,JVM允许开发者手动关闭新生代收集担保。 在开启本选项后,minor gc将不再提供新生代收集担保,而是在出现survior或年老代不够用时,抛出promotion failed异常。 |
-XX:+UseSpinning | java1.4.2和1.5需要手动启用, java6默认已启用 | 启用多线程自旋锁优化。 自旋锁优化原理 大家知道,Java的多线程安全是基于Lock机制实现的,而Lock的性能往往不如人意。 原因是,monitorenter与monitorexit这两个控制多线程同步的bytecode原语,是JVM依赖操作系统互斥(mutex)来实现的。 互斥是一种会导致线程挂起,并在较短的时间内又必须重新调度回原线程的,较为消耗资源的操作。 为了避免进入OS互斥,Java6的开发者们提出了自旋锁优化。 自旋锁优化的原理是在线程进入OS互斥前,通过CAS自旋一定的次数来检测锁的释放。 如果在自旋次数未达到预设值前锁已被释放% 相关文章推荐
|