JVM报错GC overhead limit exceeded

本文介绍了解决 JVM 因垃圾回收导致的 OutOfMemoryError 的方法,包括禁用 GCOverheadLimit、检查内存泄漏及使用 jstat 监控垃圾回收情况。

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

根据sun的说法: "if too much time is being spent in garbage collection: if more than 98% of the total time is spent in garbage collection and less than 2% of the heap is recovered, an OutOfMemoryError will be thrown."
jvm gc行为中超过98%以上的时间去释放小于2%的堆空间时会报这个错误。

处理方法:
1. 在jvm启动参数中添加 "-XX:-UseGCOverheadLimit",该参数在JDK6中默认启用("-XX:+UseGCOverheadLimit")。
  调整后的生产环境中使用的参数为: 
[javascript] view plain copy
  1. JAVA_OPTS='-Xms512m -Xmx4096m -XX:MaxPermSize=128m -XX:-UseGCOverheadLimit -XX:+UseConcMarkSweepGC'  

2. 检查是否有使用了大量内存的代码或死循环
3. 使用jstat命令监控gc行为是否正常
  jstat监控gc的命令格式为:
  jstat -gcutil [-t] [-h<lines>] <vmid> [<interval> [<count>]] 
  vmid为JVM进程id,可以用ps -ef 或 jps -lv命令查找。
  以下命令为每1秒钟输出一次gc状态,共输入5次
  1. [root@localhost bin]# jstat -gcutil 7675 1000 5  
  2.   S0     S1     E      O      P     YGC     YGCT    FGC    FGCT     GCT     
  3. .00   0.00  41.98   9.53  99.26    230    0.466   186   24.691   25.156  
  4. .00   0.00  41.98   9.53  99.26    230    0.466   186   24.691   25.156  
  5. .00   0.00  41.98   9.53  99.26    230    0.466   186   24.691   25.156  
  6. .00   0.00  41.98   9.53  99.26    230    0.466   186   24.691   25.156  
  7. .00   0.00  41.98   9.53  99.26    230    0.466   186   24.691   25.156  

经过一段时间的观察,没有再出现该异常
参考:


### 解决IntelliJ IDEA中GC overhead limit exceeded问题的方案 在开发大型项目时,IDEA可能会因内存不足而抛出`java.lang.OutOfMemoryError: GC overhead limit exceeded`错误。此错误表明垃圾回收器花费了过多时间(默认超过98%)来回收少量内存(少于2%),导致系统性能下降[^1]。以下是一些有效的解决方案,帮助调整堆内存以解决该问题。 #### 1. 增加编译器的内存限制 如果错误发生在编译阶段,可以通过增加Java编译器的内存来解决问题。具体步骤如下: - 打开IDEA设置:`File -> Settings -> Build, Execution, Deployment -> Compiler`。 - 修改`Build process heap size (Mbytes)`值,默认为700MB,建议将其增大至1024MB或更高,视机器内存情况而定[^2]。 - 点击`OK`保存设置并重新启动IDEA。 #### 2. 调整Maven项目的内存配置 对于Maven项目,需要确保Maven导入器的内存足够大。操作方法如下: - 进入`File -> Settings -> Build, Execution, Deployment -> Build Tools -> Maven -> Importing`。 - 在`VM options for importer`字段中添加参数`-Xmx1024m`,表示将最大堆内存设置为1GB。根据需求可进一步提高到2GB或更多[^5]。 - 保存设置后重新导入项目。 #### 3. 提高IDEA自身的堆内存 如果错误发生在IDEA运行期间,可能是因为IDEA本身的堆内存不足。可以通过以下方式调整: - 编辑IDEA的配置文件`idea64.exe.vmoptions`(Windows)或`idea.vmoptions`(macOS/Linux)。 - 添加或修改以下参数: ```plaintext -Xms512m -Xmx2048m -XX:MaxPermSize=512m -XX:ReservedCodeCacheSize=512m ``` - 其中`-Xmx2048m`表示将最大堆内存设置为2GB。根据硬件条件调整数值。 - 保存文件后重启IDEA[^4]。 #### 4. 禁用GC Overhead Limit检查(不推荐) 如果上述方法无法解决问题,可以临时禁用GC Overhead Limit检查。通过在JVM选项中添加以下参数实现: ```plaintext -XX:-UseGCOverheadLimit ``` 需要注意的是,这种方法仅适用于调试场景,长期使用可能导致性能下降[^1]。 #### 5. 清理不必要的缓存和依赖 有时,项目中的大量缓存或未使用的依赖也会导致内存不足。可以尝试以下操作: - 清理IDEA缓存:`File -> Invalidate Caches / Restart -> Invalidate and Restart`。 - 删除Maven本地仓库中的无用依赖:进入`.m2/repository`目录手动清理或使用命令`mvn dependency:purge-local-repository`。 --- ### 示例代码:调整IDEA VM选项 以下是一个示例配置文件`idea64.exe.vmoptions`的内容: ```plaintext -Xms512m -Xmx2048m -XX:MaxPermSize=512m -XX:ReservedCodeCacheSize=512m -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/path/to/heapdump.hprof ``` ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值