用-XX作为前缀的参数列表在jvm中可能是不健壮的,SUN也不推荐使用,后续可能会在没有通知的情况下就直接取消了;但是由于这些参数中的确有很多是对我们很有用的,比如我们经常会见到的-XX:PermSize、-XX:MaxPermSize等等;
下面我们将就Java HotSpot VM中-XX:的可配置参数列表进行描述;
这些参数可以被松散的聚合成三类:
行为参数(Behavioral Options):用于改变jvm的一些基础行为;
性能调优(Performance Tuning):用于jvm的性能调优;
调试参数(Debugging Options):一般用于打开跟踪、打印、输出等jvm参数,用于显示jvm更加详细的信息;
由于sun官方文档中对各参数的描述也都非常少(大多只有一句话),而且大多涉及OS层面的东西,很难描述清楚,所以以下是挑选了一些我们开发中可能会用得比较多的配置项,若需要查看所有参数列表,可以点击HotSpot VM Specific Options.查看原文;
首先来介绍行为参数:
参数及其默认值 | 描述 |
-XX:-DisableExplicitGC | 禁止调用System.gc();但jvm的gc仍然有效 |
-XX:+MaxFDLimit | 最大化文件描述符的数量限制 |
-XX:+ScavengeBeforeFullGC | 新生代GC优先于Full GC执行 |
-XX:+UseGCOverheadLimit | 在抛出OOM之前限制jvm耗费在GC上的时间比例 |
-XX:-UseConcMarkSweepGC | 对老生代采用并发标记交换算法进行GC |
-XX:-UseParallelGC | 启用并行GC |
-XX:-UseParallelOldGC | 对Full GC启用并行,当-XX:-UseParallelGC启用时该项自动启用 |
-XX:-UseSerialGC | 启用串行GC |
-XX:+UseThreadPriorities | 启用本地线程优先级 |
上面表格中黑体的三个参数代表着jvm中GC执行的三种方式,即串行、并行、并发;
串行(SerialGC)是jvm的默认GC方式,一般适用于小型应用和单处理器,算法比较简单,GC效率也较高,但可能会给应用带来停顿;
并行(ParallelGC)是指GC运行时,对应用程序运行没有影响,GC和app两者的线程在并发执行,这样可以最大限度不影响app的运行;
并发(ConcMarkSweepGC)是指多个线程并发执行GC,一般适用于多处理器系统中,可以提高GC的效率,但算法复杂,系统消耗较大;
性能调优参数列表:
参数及其默认值 | 描述 |
-XX:LargePageSizeInBytes=4m | 设置用于Java堆的大页面尺寸 |
-XX:MaxHeapFreeRatio=70 | GC后java堆中空闲量占的最大比例 |
-XX:MaxNewSize=size | 新生成对象能占用内存的最大值 |
-XX:MaxPermSize=64m | 老生代对象能占用内存的最大值 |
-XX:MinHeapFreeRatio=40 | GC后java堆中空闲量占的最小比例 |
-XX:NewRatio=2 | 新生代内存容量与老生代内存容量的比例 |
-XX:NewSize=2.125m | 新生代对象生成时占用内存的默认值 |
-XX:ReservedCodeCacheSize=32m | 保留代码占用的内存容量 |
-XX:ThreadStackSize=512 | 设置线程栈大小,若为0则使用系统默认值 |
-XX:+UseLargePages | 使用大页面内存 |
我们在日常性能调优中基本上都会用到以上黑体的这几个属性;
调试参数列表:
参数及其默认值 | 描述 |
-XX:-CITime | 打印消耗在JIT编译的时间 |
-XX:ErrorFile=./hs_err_pid<pid>.log | 保存错误日志或者数据到文件中 |
-XX:-ExtendedDTraceProbes | 开启solaris特有的dtrace探针 |
-XX:HeapDumpPath=./java_pid<pid>.hprof | 指定导出堆信息时的路径或文件名 |
-XX:-HeapDumpOnOutOfMemoryError | 当首次遭遇OOM时导出此时堆中相关信息 |
-XX:OnError="<cmd args>;<cmd args>" | 出现致命ERROR之后运行自定义命令 |
-XX:OnOutOfMemoryError="<cmd args>;<cmd args>" | 当首次遭遇OOM时执行自定义命令 |
-XX:-PrintClassHistogram | 遇到Ctrl-Break后打印类实例的柱状信息,与jmap -histo功能相同 |
-XX:-PrintConcurrentLocks | 遇到Ctrl-Break后打印并发锁的相关信息,与jstack -l功能相同 |
-XX:-PrintCommandLineFlags | 打印在命令行中出现过的标记 |
-XX:-PrintCompilation | 当一个方法被编译时打印相关信息 |
-XX:-PrintGC | 每次GC时打印相关信息 |
-XX:-PrintGC Details | 每次GC时打印详细信息 |
-XX:-PrintGCTimeStamps | 打印每次GC的时间戳 |
-XX:-TraceClassLoading | 跟踪类的加载信息 |
-XX:-TraceClassLoadingPreorder | 跟踪被引用到的所有类的加载信息 |
-XX:-TraceClassResolution | 跟踪常量池 |
-XX:-TraceClassUnloading | 跟踪类的卸载信息 |
-XX:-TraceLoaderConstraints | 跟踪类加载器约束的相关信息 |
当系统出现问题的时候,又不能使用外部跟踪工具(比如JProfiler……)的情况下,以上的这些参数就会发挥重大作用了,比如dump堆信息、打印并发锁……
相关推荐
**JVM启动参数大全** Java虚拟机(JVM)是Java程序运行的基础,它负责解析字节码并执行Java代码。在开发和调优Java应用时,了解和使用JVM启动参数至关重要。这些参数可以调整JVM的行为,优化内存分配、垃圾收集、...
JVM启动参数的正确配置对于优化应用程序性能、控制内存使用、诊断问题和调试至关重要。本篇文章将详细介绍JVM的一些标准启动参数,以帮助开发者更好地理解和应用它们。 1. **-client与-server** `-client` 和 `-...
本篇文件内容主要介绍了JVM优化的第三部分,重点围绕Tomcat参数调优、JVM参数调优、JVM字节码优化以及代码优化等几个方面。下面是针对这些知识点的详细解释: 1. Tomcat参数调优 在Tomcat参数调优部分,首先介绍了...
JVM 参数与系统性能的优化 在 Java 虚拟机(JVM)中,参数设置对系统性能的影响是至关重要的。通过设置合适的 JVM 参数,可以提高系统性能,减少垃圾回收的频率和时间,提高应用程序的执行效率。 第一点:设置堆栈...
了解JVM的启动过程和工作原理对于优化Java程序性能至关重要。通过调整JVM参数,我们可以控制堆大小、垃圾收集策略、线程栈大小等,以达到最佳的运行效果。例如,通过-Xms和-Xmx设置堆内存大小,-XX:+UseG1GC选择垃圾...
1. **-Xms**: 设置JVM启动时的初始堆内存大小。例如,`-Xms1024m`表示初始堆内存为1024MB。 2. **-Xmx**: 设置JVM的最大堆内存大小。例如,`-Xmx1024m`表示最大堆内存为1024MB。 3. **-XX:PermSize**: 设置永久...
JVM启动参数的选择和配置,对于Java应用程序的性能和稳定性至关重要。标准参数为开发者提供了稳定的基线,而非标准与非Stable参数则为追求极致性能的应用场景提供了更多可能性。然而,合理利用这些参数,不仅需要对...
根据Java启动参数的不同分类,我们可以将其分为标准参数(-)、非标准参数(-X)以及非稳定参数(-XX)。本文主要关注标准参数,这是JVM实现必须遵循的通用选项,具有较高的兼容性。 #### 二、标准参数详解 ##### ...
- **`-server`**:表示以服务端模式启动JVM,这会带来更好的性能,但启动时间稍长。 - **`-Djava.awt.headless=true`**:在没有图形界面的Linux服务器上,可以避免某些与图形操作相关的异常。 #### 四、并发配置...
Tomcat7 安装使用及 JVM 连接数参数调优 Tomcat7 是一个流行的 Java Web 服务器,主要用于部署和管理基于 Java 的 Web 应用程序。为了确保 Tomcat7 的稳定运行和高效性能,需要对其进行合理的安装、配置和优化。...
- **参数调优**: 根据应用的特点调整JVM启动参数,例如增大或减小堆内存大小、选择合适的垃圾回收器。 - **代码审查**: 定期进行代码审查,识别和消除可能导致性能瓶颈的代码。 - **监控与分析**: 使用工具对运行时...
1. **堆内存大小**:`-Xms`和`-Xmx`分别设置JVM启动时和最大可用的堆内存大小。根据服务器硬件和应用需求,适当调整这两个值可以防止内存溢出或过早垃圾回收。 2. **新生代和老年代大小**:`-Xmn`设置年轻代大小,`...
类数据共享(Class Data Sharing,CDS)可以减少启动时间和内存占用,通过预先打包的类数据归档文件,多个JVM实例可以共享相同的类信息。 总之,JVM性能优化是一个涵盖广泛且深度丰富的主题,涉及内存管理、垃圾...
- `-Xms`: 设置JVM启动时的初始堆内存大小。 - `-Xmx`: 设置JVM的最大堆内存限制。 - **-Xmn**: 设置年轻代的大小。年轻代主要负责存放新创建的对象,适当调整该值可以优化短生命周期对象的回收效率。 - **-XX:...
初始内存(`-Xms`)是JVM启动时分配的最小内存,而最大内存(`-Xmx`)则是JVM允许的最大内存使用量。合理设置这两个值有助于避免因内存不足导致的性能下降或系统崩溃。 垃圾回收机制是JVM自动清理不再使用的对象以...
5. **JVM参数调整**:理解JVM启动参数的意义和作用,如-Xms、-Xmx、-XX:+UseConcMarkSweepGC等,是提升系统性能的关键。教程会指导如何根据系统资源和应用需求设置合适的参数。 6. **并发与多线程**:JVM提供了丰富...
- **作用**:通过这两个参数可以合理配置JVM启动时的堆内存大小,避免因内存不足或过大导致的问题。 #### 四、栈的分配参数 ##### -Xss - **作用**:设置线程栈大小。 - **默认值**:通常默认值为1MB。 - **调整...
JVM的参数调整也是优化的关键。例如,可以通过-Xms和-Xmx设置堆内存的初始大小和最大大小,避免频繁的内存扩展导致的性能波动。-XX:NewRatio可以调整新生代和老年代的比例,-XX:SurvivorRatio则影响新生代的Eden和...
这两个参数确保了JVM启动时和运行过程中的内存分配。 2. **年轻代与老年代**: - `-XX:NewRatio`:设定年轻代与老年代的比例,例如`-XX:NewRatio=3`表示年轻代占1份,老年代占3份。 - `-XX:SurvivorRatio`:设定...