JVM 基本参数

本文介绍了JVM的各种参数,包括设置类搜索路径、JVM运行模式、系统属性等基础参数,以及混合模式执行、禁用类垃圾回收等-X参数。同时涵盖了如何通过不同参数启用或禁用断言、加载本地代理库等高级配置。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

基本的JVM参数:
-classpath, -cp: 设置类搜索路径
-client, -server: JVM运行模式, 不同的模式相应的一些默认参数不一样, 比如垃圾回收策略
-D<propertyName>=value: 设置JVM系统属性, 可通过System.getProperty(“propertyName”)获取
-verbose[:gc|class|jni]: 显示JVM运行过程中的gc,class load, jni调用, 如:java -verbose:jni -verbose:class
-version[:value]: 显示JVM版本或指定以某个版本运行, 如: java -version:1.6
-showversion: 显示JVM版本后再运行
-jre-restrict-search | -jre-no-restrict-search: include/exclude user private JREs in the version search 很少用, 不清楚详细情况
-ea[:<packagename>...|:<classname>], -enableassertions[:<packagename>...|:<classname>]: 针对(指定的包或类)启用断言
-da[:<packagename>...|:<classname>], -disableassertions[:<packagename>...|:<classname>]: 针对(指定的包或类)禁用断言
-esa | -enablesystemassertions: 启用系统级断言
-dsa | -disablesystemassertions: 禁用系统级断言
-agentlib:<libname>[=<options>]: 指定加载本地代理库(dll,so文件,注:不加后缀)
-agentpath:<pathname>[=<options>]: 指定加载本地代理库的路径(全路径)
-javaagent:<jarpath>[=<options>]: 指定代理库的jar路径
-splash:<imagepath>: 指定splash的图片路径
-X: JVM的非标准参数, 它比较复杂, 下面详细介绍 -X

  • -Xmixed: 以混合模式执行(默认)
  • -Xint: 只是解释模式执行
  • -Xbootclasspath:<directories and zip/jar files separated by ;>: 设置JVM bootstrap classloader的搜索路径(JVM class loader: bootstrap classloader, extension classloader, system classloader)
  • -Xbootclasspath/a:<directories and zip/jar files separated by ;>: 添加到bootstrap classpath末尾
  • -Xbootclasspath/p:<directories and zip/jar files separated by ;>: 插入到bootstrap classpath之前
  • -Xnoclassgc: 禁用类垃圾回收
  • -Xincgc: 启动增量垃圾收集器,缺省是关闭的。增量垃圾收集器能减少偶然发生的长时间的垃圾回收造成的暂停时间。但增量垃圾收集器和应用程序并发执行,因此会占用部分CPU在应用程序上的功能
  • -Xloggc:<file>: 将虚拟机每次垃圾回收的信息写到日志文件中,文件名由file指定,内容和-verbose:gc输出内容相同
  • -Xbatch: 禁用后台编译功能。通常虚拟机将编译方法作为后台任务执行,在后台编译完成之前,采用解释方式执行方法。-Xbatch选项禁用后台编译功能,所以所有方法的编译作为前台任务直到结束
  • -Xms<size>: 设置JVM堆的初始大小
  • -Xmx<size>: 设置JVM堆的最大值
  • -Xss<size>: 设置JVM栈大小
  • -Xprof: 输出CPU运行时的诊断信息
  • -Xfuture: 对类文件进行严格格式检查,以保证类代码符合类代码规范。为保持向后兼容,虚拟机缺省不进行严格的格式检查
  • -Xrs: 减少虚拟机中操作系统的信号(singals)的使用。该参数通常用在虚拟机以后台服务方式运行时使用
  • -Xcheck:jni: 调用JNI函数时进行附加的检查,特别地虚拟机将校验传递给JNI函数参数的合法性,在本地代码中遇到非法数据时,虚拟机将报一个致命错误而终止。使用该参数后将造成性能下降
  • -Xshare:off: 不在JVM进程间共享类数据
  • -Xshare:auto: 自动共享类数据(默认)
  • -Xshare:on: 开户类数据共享
  • -Xshare:dump: 生成类数据共享
<think>好的,用户想了解如何配置和优化JVM内存参数。首先,我需要回忆一下JVM内存管理的基本知识,包括堆内存、非堆内存以及各个参数的作用。用户可能对-Xms、-Xmx这些基础参数比较熟悉,但可能还需要更深入的调优建议。 接下来,我需要查看用户提供的引用内容。引用[1]提到了8G和16G内存的配置模板,这可以作为具体案例。引用[3]解释了-Xms和-Xmx的作用,引用[2]提到了生成堆转储文件的参数,引用[4]则区分了标准和非标准参数。这些引用内容需要整合到回答中,确保每个建议都有依据。 用户的问题可能涉及如何根据应用需求调整内存大小,选择合适的垃圾收集器,以及处理内存溢出的情况。需要考虑不同场景下的配置,比如高吞吐量还是低延迟,以及如何监控和诊断内存问题。 另外,用户可能不知道如何选择CMS和G1垃圾收集器,需要解释两者的适用场景。同时,内存溢出时的堆转储参数也很重要,引用[2]中的-XX:+HeapDumpOnOutOfMemoryError应该被提到。 需要确保回答结构清晰,分步骤说明配置方法,并给出优化建议。还要注意引用标识的正确添加,比如在提到初始堆大小时引用[3],在给出配置模板时引用[1]。 最后,生成的相关问题要围绕JVM参数配置的常见疑问,比如不同垃圾收集器的选择、参数验证方法、内存泄漏处理等,帮助用户进一步学习。</think>### JVM内存参数配置与优化指南 #### 一、基础参数配置 1. **堆内存设置** - 初始堆大小:`-Xms<size>`(例如`-Xms4g`) - 最大堆大小:`-Xmx<size>`(例如`-Xmx8g`) 建议两者设为相等值,避免堆扩展引发性能波动[^3]。 2. **非堆内存设置** - 元空间:`-XX:MetaspaceSize`和`-XX:MaxMetaspaceSize` - 代码缓存:`-XX:ReservedCodeCacheSize` 元空间默认不设上限,建议设置`MaxMetaspaceSize`防止内存泄漏[^4]。 #### 二、配置模板示例 ```bash # 8G物理内存配置(CMS收集器) -Xms4g -Xmx4g -XX:+UseConcMarkSweepGC -XX:SurvivorRatio=8 -XX:+HeapDumpOnOutOfMemoryError [^1][^2] # 16G物理内存配置(G1收集器) -Xms12g -Xmx12g -XX:+UseG1GC -XX:MaxGCPauseMillis=200 -XX:G1HeapRegionSize=32m ``` #### 三、优化策略 1. **垃圾收集器选择** - **CMS**:适合要求低延迟的Web应用(堆<8G) - **G1**:适合大堆内存(>8G)和可预测暂停时间场景 - **ZGC**:超低延迟(JDK11+) 2. **内存监控工具** - `jstat -gcutil <pid>` 查看GC统计 - `jmap -histo:live <pid>` 分析对象分布 - VisualVM/Mission Control图形化监控 3. **内存溢出处理** 添加`-XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/path`自动生成dump文件,结合MAT工具分析对象引用链。 #### 四、调优验证方法 1. 通过`-XX:+PrintGCDetails`查看GC日志 2. 使用压测工具模拟高并发场景 3. 观察Full GC频率(建议每小时<1次)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值