Caused by: java.lang.OutOfMemoryError: GC overhead limit exceeded
问题描述
垃圾回收为了释放较小的空间而占用了大量时间造成的。通常是设置的堆内存太小,导致没有足够的内存。
解决方法
1、检查程序有没有死循环或者其他一些导致内存被大量占用的程序
2、程序本身需要大内存,需要设置增加内存
tomcat下./bin/catalina.sh文件在cygwin=false这一行的上面
原本:
JAVA_OPTS="-server -Xms32m -Xmx64m -XX:PermSize=64M -XX:MaxPermSize=128m"
修改后:
JAVA_OPTS="-server -Xms64m -Xmx128m -XX:PermSize=128M -XX:MaxPermSize=256m"
-server:一定要作为第一个参数,在多个CPU时性能佳
-Xms:初始Heap大小,使用的最小内存,cpu性能高时此值应设的大一些
-Xmx:java heap最大值,使用的最大内存
上面两个值是分配JVM的最小和最大内存,取决于硬件物理内存的大小
-XX:PermSize:设定内存的永久保存区域
-XX:MaxPermSize:设定最大内存的永久保存区域
本文探讨了 Java 应用程序中出现 OutOfMemoryError 的原因,特别是 GCOverheadLimitExceeded 错误,通常由堆内存设置不当引起。文章提供了检查程序内存使用情况的方法,包括查找死循环和调整 JVM 堆内存配置的具体步骤。
9278

被折叠的 条评论
为什么被折叠?



