GC overhead limit exceeded

"GC overhead limit exceeded"表示JVM垃圾收集一直在运行导致应用运行缓慢。在垃圾收集后,如果Java进程花费大约超过98%的时间来进行GC且恢复不到2%的堆内存,就会抛出java.lang.OutOfMemoryError异常,一般是因为大量运行时数据被勉强填充到了堆内存中。

解决办法:增加堆内存,并使用-XX:-UseGCOverheadLimit参数关闭这个限制。

另外就是分析jvm的堆栈和内存,结合代码判断出导致问题的代码进行优化。

jps -ml 查看jvm的pid是多少,下面用的到。

jstack 打印线程的栈信息(pid就是上面查询到的jvm的pid)

  • jstack -l pid   

查看类的数量和占用内存

  • jmap -histo pid | more

也可以导出内存dump之后用mat工具分析

jmap -dump:format=b,file=dump.hprof pid

  • 文件可能较大,一定要小心指定目录的空余磁盘是否足够
  • 导出Dump文件
    • 使用MAT工具分析
  • pid可通过jps获取

如果不能dump内存则可以直接查看内存中对象的数量和大小来分析:

  • 1
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值