JVM 内存参数设置

本文详细介绍了如何在不同环境中配置JVM参数,包括本地环境、Eclipse、Tomcat、WebLogic、WebSphere、JBoss等,并解释了堆内存与非堆内存的区别及设置方法。
部署运行你感兴趣的模型镜像

一、本地环境中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 命令。

 

您可能感兴趣的与本文相关的镜像

GPT-oss:20b

GPT-oss:20b

图文对话
Gpt-oss

GPT OSS 是OpenAI 推出的重量级开放模型,面向强推理、智能体任务以及多样化开发场景

直接内存是通过 `ByteBuffer` 类申请的,它会绕过 JVM 的堆内存,直接在操作系统的本地内存中分配空间。可以通过参数 `-XX:MaxDirectMemorySize` 来限制直接内存的大小[^1]。 JVM 参数设置直接内存有多种方式: 1. **命令行设置**:在启动 Java 程序时,直接在命令行中添加 `-XX:MaxDirectMemorySize` 参数。例如: ```sh java -XX:MaxDirectMemorySize=256m -jar your-application.jar ``` 这里将直接内存的最大大小设置为 256MB。 2. **环境变量设置**:可以使用 `JAVA_OPTS` 或 `JVM_OPTS` 环境变量来设置 JVM 参数。例如,在 Linux 系统中,可以在启动脚本中添加如下内容: ```sh export JAVA_OPTS="-XX:MaxDirectMemorySize=256m" java $JAVA_OPTS -jar your-application.jar ``` 3. **应用服务器配置文件设置**:如果是在应用服务器(如 Tomcat)中运行 Java 应用,可以在服务器配置文件中添加 JVM 参数。以 Tomcat 为例,可以在 `catalina.sh`(Linux)或 `catalina.bat`(Windows)文件中添加: ```sh JAVA_OPTS="-XX:MaxDirectMemorySize=256m" ``` 4. **IDE 设置**:在 IDE(如 IntelliJ IDEA 或 Eclipse)中运行 Java 程序时,可以在运行配置中设置 JVM 参数。在 IntelliJ IDEA 中,打开“Run/Debug Configurations”,在“VM options”字段中添加 `-XX:MaxDirectMemorySize=256m`。 5. **Spring Boot 配置文件设置**:在 Spring Boot 应用中,可以在 `application.properties` 或 `application.yml` 文件中设置 JVM 参数。不过,Spring Boot 本身不直接支持在配置文件中设置 JVM 参数,但可以通过配置启动脚本或使用环境变量来实现。 6. **容器化应用中的配置**:如果应用是容器化部署(如 Docker),可以在 Dockerfile 或 Docker 运行命令中设置 JVM 参数。例如,在 Dockerfile 中可以添加: ```Dockerfile ENV JAVA_OPTS="-XX:MaxDirectMemorySize=256m" ```
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值