"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内存则可以直接查看内存中对象的数量和大小来分析: