GC overhead limit exceeded 分析及解决方案

GC overhead limit exceeded 分析

官方定义的解释:当JVM花费超过98%的时间用来做GC(垃圾回收)并且只回收了不到2%的堆内存时,会抛出此异常。

通俗点说,其实就是我们的程序几乎把所有的内存都用完了,而GC花了很多时间去清理内存垃圾,但是清理的效率很低,导致内存不够用了,所以就会发生此异常。

解决方案

1. 增大堆内存

增大堆内存

2. 优化代码

其实增大堆内存是一种治标不治本的方法,只能说目前解决了问题。

我们应该找出抛出此异常的根本原因,所以我们就需要去检查程序中是否存在 死循环 或者 大量消耗内存 的代码,优化这一部分的代码。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
GC overhead limit exceededJava虚拟机在进行垃圾回收时出现的一种异常。它表示垃圾回收占用了过多的CPU时间,但仍然没有回收到足够的内存。这种异常通常是由于应用程序占用了大量内存或者存在内存泄漏导致的。 GC overhead limit exceeded异常的解决方法包括增加Java虚拟机的堆内存大小,调整垃圾回收相关的参数,或者优化代码中的内存使用。具体的解决方法取决于出现异常的具体上下文。 对于Java heap space异常,可以考虑增加Java虚拟机的堆内存大小。可以通过设置-Xmx参数来增加最大堆内存,例如java -Xmx2g表示设置最大堆内存为2GB。另外,也可以检查代码中是否存在内存泄漏的地方,确保内存使用合理。 对于PermGen space异常,可以考虑增加Java虚拟机的永久代内存大小。可以通过设置-XX:MaxPermSize参数来增加最大永久代内存,例如java -XX:MaxPermSize=256m表示设置最大永久代内存为256MB。此外,也可以检查是否存在类加载器泄漏或者大量动态生成类的情况,及时释放无用的类和资源。 总之,GC overhead limit exceeded异常通常是由于内存占用过多或者内存泄漏导致的。通过增加堆内存大小、调整垃圾回收参数、优化代码中的内存使用等方法,可以解决这个异常。具体的解决方法需要根据具体的上下文进行调整。<span class="em">1</span><span class="em">2</span><span class="em">3</span><span class="em">4</span>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值