JVM 内存参数设置

出处:http://blog.youkuaiyun.com/tiercel2008/article/details/6956816

 

一、本地环境中JVM参数设置:

    在本地环境变量中New一个JAVA_OPTS变量名:

    variable name: JAVA_OPTS

    variable value:  -Xms256M -Xmx512M -XX:PermSize=256M -XX:MaxPermSize=512M

二、eclipse中JVM参数设置:

    打开eclipse-窗口-首选项-Java-已安装的JRE(对在当前开发环境中运行的java程序皆生效,也就是在eclipse中运行的java程序)编辑当前使用的JRE,在缺省VM参数中输入:-Xmx128m -Xms64m -Xmn32m -Xss16m

三、Tomcat服务器中JVM参数设置:

    Tomcat默认可以使用的内存为128MB,Windows下,在文件{tomcat_home}/bin/catalina.bat,Unix下,在文件{tomcat_home}/bin/catalina.sh的前面,增加如下设置:
JAVA_OPTS=’-Xms[初始化内存大小] -Xmx[可以使用的最大内存]’例如:
    set JAVA_OPTS=-Xmx512m -Xms512m -Xmn64m -Xss2m 或者
    set CATALINA_OPTS=-Xmx512m -Xms512m -Xmn64m -Xss2m 

四、Weblogic服务器中JVM参数设置:

    a) 编辑Weblogic Server启动脚本文件;
        BEA_HOME\user_projects\domains\domain-name\startWebLogic.cmd(startWebLogic.sh on Unix)
        BEA_HOME\user_projects\domains\domain-name\startManagedWebLogic.cmd(startManagedWebLogic.sh on Unix) –这个是做集群的时候用的
    b) 编辑set JAVA_OPTIONS命令,如:set JAVA_OPTIONS=-Xms256m –Xmx256m;
       (在UNIX下把MEM_ARGS=”-Xms1024m -Xmx1024m -Xmn128m”加到上述两个.sh文件中即可)
    c) 保存,重启即可。
    注:在WebLogic中,为了获得更好的性能,BEA公司推荐最小Java堆等于最大Java堆。

五、Websphere服务器中JVM参数设置:

    选择 服务器-> 应用程序服务器-> Server1-> 进程定义->Java 虚拟机。
滚动到初始堆大小和最大堆大小字段并设置值。单击确定以保存更改。

六、JBoss服务器中JVM参数设置:

    编辑{jboss}/bin/run.conf,  在文件的底部找到对参数JAVA_OPTS进行设置的地方。这个参数会最后传到jvm里

七、JVM内存分类:

    java内存可以分为堆内存和非堆内存:
    堆是给开发人员用的,是在JVM启动时创建;非堆是留给JVM自己用的,用来存放类型(类和接口)的信息。它和堆不同,运行期内GC不会释放空间。如果web app用了大量的第三方jar或者应用有太多的class文件而恰好MaxPermSize设置较小,超出了就会导致这块内存的占用过多造成溢出,或者服务器如tomcat热部署时侯不会清理前面加载的环境,只会将context更改为新部署的,非堆存的内容就会越来越多,热部署上几次就java.lang.OutOfMemoryError: PermGen space。
    a) 堆内存设置:程序可以到达的,可以操作的
       -Xms 初始堆内存 默认物理内存1/64,也是最小分配堆内存。当空余堆内存小于40%时,会增加到-Xms的最大限制 
       -Xmx 最大堆内存分配 默认物理内存1/4,当空余堆内存大于70%时,会减小到-Xms的最小限制。
       一般设置 -Xms和Xms大小相等
     b) 非堆内存设置
      -XX:PermSize 非堆内存的初始值,默认物理内存的1/64 ,也是最小非堆内存。
      -XX:MaxPermSize 非堆内存最大值,默认物理内存的1/4。

八、查看堆大小信息:

    a) 在程序中查看,返回值单位是字节,当然还有其他JVM参数可以查看。
         Runtime.getRuntime().maxMemory(); 
    b) 在命令行执行 jvisualvm 命令 或者 在命令行执行jconsole 命令。

<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、付费专栏及课程。

余额充值