出现GC overhead limit exceeded 的解决方案

本文介绍了解决MyEclipse中创建Maven项目时出现的“GCoverheadLimitExceeded”错误的方法。该问题源于JVM内存配置不当,通过调整myeclipse.ini文件中的-Xmx参数值至1024m得以解决。

     当我在使用MyEclispe IDE创建Maven项目的时候出现  "An internal error occurred during: “Build Project”. GC overhead limit exceeded",刚开始以为我clean一下,然后重启MyEclipse就可以了,后来发现并不是这样。既然出错就要去寻找问题的根源,那么问题出在哪里呢?

        在解决这个问题的时候,我寻找了一些资料,发现GC overhead limt exceed检查是Hotspot VM 1.6定义的一个策略,通过统计GC时间来预测是否要OOM了,提前抛出异常,防止OOM发生。Sun 官方对此的定义是:“并行/并发回收器在GC回收时间过长时会抛出OutOfMemroyError。过长的定义是,超过98%的时间用来做GC并且回收 了不到2%的堆内存。用来避免内存过小造成应用不能正常工作

        这时候就需要认真的去考虑了,既然是配置内存出了问题,那么就应该去到相应的配置文件下面去找,MyEclispe IDE的相关内存配置文件在myeclispe.ini,当然,在我们打开的时候就会清楚的看到下面的这一段代码:

#utf8 (do not remove)
-startup
plugins/org.eclipse.equinox.launcher_1.3.0.v20130327-1440.jar
--launcher.library
plugins/org.eclipse.equinox.launcher.i18n.win32.win32.x86_64_3.2.0.v201103301700
-vm
binary/com.sun.java.jdk7.win32.x86_64_1.7.0.u45/bin/javaw.exe
-install
D:\mytools\MyEclipse
-vmargs
-Xmx768m
-XX:MaxPermSize=320m
-XX:ReservedCodeCacheSize=64m
-Dosgi.nls.warnings=ignore</span>
可以很清楚的看到有一段 -Xmx768m 的配置,它是作为最大占有内存,当出现刚刚的错误的时候说明当前已经超过这个设定值,所以我们可以将这个最大占有内存做下修改,调整为1024m,目前这个设定值已经足够使用了,当然有的人会说将" -XX:MaxPermSize",同样也设定为1024m或者更大的时候,但是我感觉没必要,当我们在编译文件的时候就让它一直处在最大占有内存,往往会出现程序卡住的现象。所以一切还是要根据具体情况做具体分析以及解决,达到最佳的效果。



### Java中解决GC Overhead Limit Exceeded错误的具体方法 `java.lang.OutOfMemoryError: GC overhead limit exceeded` 错误表明JVM在垃圾回收上花费了过多的时间(超过98%的CPU时间),但仅能回收少量内存(少于2%的堆空间)。以下是几种有效的解决方案: #### 1. **增加堆内存** 通过调整JVM参数来增大可用堆内存是一种常见的做法。可以通过以下命令设置最大堆大小和初始堆大小,并启用G1垃圾收集器: ```bash java -Xmx2048m -Xms1024m -XX:+UseG1GC YourApplication ``` 此操作可以缓解因堆内存不足而导致的频繁垃圾回收问题[^2]。 #### 2. **优化代码逻辑** - **检查内存泄漏** 需要特别关注静态集合类(如 `ArrayList`, `HashMap`)、缓存以及长时间存活的对象引用。如果这些对象未被正确释放,可能导致内存占用过高。 - **及时关闭资源** 数据库连接、文件流以及其他外部资源应始终在其使用完毕后立即关闭,避免不必要的内存消耗。 - **减少临时对象创建** 尤其是在循环体内,尽量避免创建大量的短生命周期对象。例如,在字符串拼接时优先使用 `StringBuilder` 而非简单的 `+` 运算符[^2]。 #### 3. **改进数据结构设计** 当涉及大规模数据处理时,选择合适的数据结构至关重要。例如,对于大容量的键值映射场景,默认构造函数可能引发性能瓶颈;因此建议显式指定哈希表的初始化容量及其负载因子以降低扩容频率: ```java Map<String, String> map = new HashMap<>(initialCapacity, loadFactor); ``` #### 4. **利用诊断工具分析内存状况** 为了深入理解应用程序的实际运行情况,可借助专门的调试工具完成进一步排查工作: - 使用 `jmap` 导出当前进程的堆转储快照并导入至第三方解析软件(比如 Eclipse MAT 或 VisualVM)进行可视化展示; ```bash jmap -dump:live,format=b,file=heap.bin <PID> ``` - 利用 JConsole 和 VisualVM 实现动态监测功能,观察各代区分布趋势变化规律以便定位潜在风险源[^2]。 #### 5. **调优垃圾回收算法配置** 除了默认采用 Parallel Scavenge 收集方式外,还可以尝试切换到其他更适合特定业务需求类型的清理模式,像 CMS (Concurrent Mark Sweep) 或者 G1 (Garbage First),具体实现如下所示: ```bash # 启动CMS并发标记清除收集器 java ... -XX:+UseConcMarkSweepGC ... # 开启G1垃圾收集器支持 java ... -XX:+UseG1GC ... ``` 以上措施能够显著改善由高比例垃圾回收所引起的异常现象发生概率,从而保障系统的稳定性和响应速度[^1][^2]。 ---
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值