linux下的tomcat jvm内存:java.lang.OutOfMemoryError: Java heap space

本文详细介绍了Java环境中常见的两种内存溢出错误:PermGenSpace和JavaHeapSpace,并提供了具体的解决方案。针对Tomcat服务器环境,给出了调整JVM内存配置的具体步骤。

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



常见的内存溢出有以下两种:
java.lang.OutOfMemoryError: PermGen space
java.lang.OutOfMemoryError: Java heap space
 
---------------------------------------------------------
这里以tomcat环境为例,其它WEB服务器如jboss,weblogic等是同一个道理。

一、java.lang.OutOfMemoryError: PermGen space
PermGen space的全称是Permanent Generation space,是指内存的永久保存区域,
这块内存主要是被JVM存放Class和Meta信息的,Class在被Loader时就会被放到PermGenspace中,
它和存放类实例(Instance)的Heap区域不同,GC(GarbageCollection)不会在主程序运行期对
PermGen space进行清理,所以如果你的应用中有很多CLASS的话,就很可能出现PermGenspace错误,
这种错误常见在web服务器对JSP进行pre compile的时候。如果你的WEB APP下都用了大量的第三方jar,其大小
超过了jvm默认的大小(4M)那么就会产生此错误信息了。
解决方法: 手动设置MaxPermSize大小
建议:将相同的第三方jar文件移置到tomcat/shared/lib目录下,这样可以达到减少jar文档重复占用内存的目的。
 
二、java.lang.OutOfMemoryError: Java heap space
JVM堆的设置是指java程序运行过程中JVM可以调配使用的内存空间的设置.JVM在启动的时候会自动设置Heapsize的值,
其初始空间(即-Xms)是物理内存的1/64,最大空间(-Xmx)是物理内存的1/4。可以利用JVM提供的-Xmn -Xms-Xmx等选项可
进行设置。Heap size 的大小是Young Generation 和Tenured Generaion之和。
提示:在JVM中如果98%的时间是用于GC且可用的Heap size 不足2%的时候将抛出此异常信息。
提示:Heap Size最大不要超过可用物理内存的80%,一般的要将-Xms和-Xmx选项设置为相同,而-Xmn为1/4的-Xmx值。 
解决方法:手动设置Heap size
----------------------------------------------------------
 
Linux下修改JVM内存大小:
要添加在tomcat 的bin 下catalina.sh 里,位置cygwin=false前。注意引号要带上,红色的为新添加的.
# OS specific support. $var _must_ be set to either true orfalse.
JAVA_OPTS="-Xms256m -Xmx512m-XX:PermSize=128m -XX:MaxPermSize=256m"
cygwin=false


---------------------------------------------------------
各参数的比例:
Xmx与PermSize的和不可超过JVM可获得的总内存
PermSize不可大于Xmx
===============================================
如何设置Tomcat的JVM虚拟机内存大小
可以给Java虚拟机设置使用的内存,但是如果你的选择不对的话,虚拟机不会补偿。可通过命令行的方式改变虚拟机使用内存的大小。如下表所示有两个参数用来设置虚拟机使用内存的大小。
参数
描述
-Xms
JVM初始化堆的大小
-Xmx
JVM堆的最大值
这两个值的大小一般根据需要进行设置。初始化堆的大小执行了虚拟机在启动时向系统申请的内存的大小。一般而言,这个参数不重要。但是有的应用程序在大负载的情况下会急剧地占用更多的内存,此时这个参数就是显得非常重要,如果虚拟机启动时设置使用的内存比较小而在这种情况下有许多对象进行初始化,虚拟机就必须重复地增加内存来满足使用。由于这种原因,我们一般把-Xms和-Xmx设为一样大,而堆的最大值受限于系统使用的物理内存。一般使用数据量较大的应用程序会使用持久对象,内存使用有可能迅速地增长。当应用程序需要的内存超出堆的最大值时虚拟机就会提示内存溢出,并且导致应用服务崩溃。因此一般建议堆的最大值设置为可用内存的最大值的80%。
Tomcat默认可以使用的内存为128MB,在较大型的应用项目中,这点内存是不够的,需要调大。

### TomcatLinux上运行时出现Java内存不足问题的解决方案 当TomcatLinux环境中运行并抛出`java.lang.OutOfMemoryError: Java heap space`错误时,这通常表明分配给JVM的堆空间不足以支持当前应用程序的工作负载。以下是详细的分析和解决方法: #### 1. 增加JVM内存配置 通过修改Tomcat启动脚本中的JVM参数来增加可用堆内存是最常见的解决办法之一。具体操作如下: - 编辑`/path/to/tomcat/bin/catalina.sh`文件(对于Windows环境则是`catalina.bat`),找到或新增`JAVA_OPTS`变量定义部分。 - 设置合适的初始堆大小(`-Xms`)和最大堆大小(`-Xmx`)。推荐将两者设为相同值以避免动态调整带来的性能损耗[^2]。 ```bash export JAVA_OPTS="-Xms512m -Xmx2g" ``` 以上命令表示初始化堆大小为512MB,而最大可扩展至2GB。根据实际硬件资源情况适当调整这些数值。 #### 2. 调整垃圾回收器(GC)策略 不同的GC算法会对内存管理效率产生影响。可以尝试切换到更高效的收集器比如G1 Garbage Collector (G1 GC),它特别适合于具有大量数据的应用场景。 ```bash export JAVA_OPTS="$JAVA_OPTS -XX:+UseG1GC" ``` 此外还可以启用一些优化选项进一步提升表现: ```bash export JAVA_OPTS="$JAVA_OPTS -XX:MaxGCPauseMillis=200 -XX:InitiatingHeapOccupancyPercent=35" ``` 这里设置了期望的最大暂停时间为200毫秒以及触发标记周期前允许占用的比例为35%[^4]。 #### 3. 定期监控与调优 除了静态地提高内存限额外,还需要借助工具持续观察系统状态以便做出精准决策。例如利用jstat,jmap等内置诊断指令获取实时统计信息; 或者集成专业的APM(Application Performance Management)平台如New Relic,Prometheus+Grafana来进行全方位跟踪评估。 #### 4. 减少不必要的对象创建 从源码层面出发寻找潜在浪费也是不可忽视的一环。审查业务逻辑是否存在频繁实例化临时实体的行为, 并考虑采用池技术复用已有组件从而降低整体消耗. --- ### 示例代码片段展示如何设置环境变量 下面给出一段简单的Shell脚本来完成上述提到的部分设定工作: ```shell #!/bin/bash # Define base directory of your Apache Tomcat installation. TOMCAT_HOME="/usr/local/apache-tomcat" # Set JVM options including heap size and garbage collection settings. JAVA_OPTS="-Xms512m -Xmx2g \ -XX:+UseG1GC \ -XX:MaxGCPauseMillis=200 \ -XX:InitiatingHeapOccupancyPercent=35" # Export the variable so it can be picked up by catalina.sh when starting Tomcat. export JAVA_OPTS cd $TOMCAT_HOME/bin && ./startup.sh ``` 执行该脚本将会按照预定义好的规格启动Tomcat服务进程。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值