java.lang.OutOfMemoryError: GC overhead limit exceeded 问题分析和解决

来源:互联网 发布:vb中名称和caption 编辑:程序博客网 时间:2024/05/20 14:44

在项目历史数据导入过程中,出现了应用无法访问的情况。立刻对Weblogic进行分析,发现Weblogic的内存、线程等性能良好,Server也是Running的状态。随后查看了Weblogic日志,在日志中发现下述错误

[plain] view plain copy
  1. java.lang.OutOfMemoryError: GC overhead limit exceeded  
  2.     at weblogic.utils.http.HttpRequestParser.<init>(HttpRequestParser.java:94)  
  3.     at weblogic.servlet.internal.ServletRequestImpl$RequestInputHelper.<init>(ServletRequestImpl.java:2390)  
  4.     at weblogic.servlet.internal.ServletRequestImpl.<init>(ServletRequestImpl.java:105)  
  5.     at weblogic.servlet.internal.HttpConnectionHandler.<init>(HttpConnectionHandler.java:115)  
  6.     at weblogic.servlet.internal.MuxableSocketHTTP.<init>(MuxableSocketHTTP.java:40)  
  7.     Truncated. see log file for complete stacktrace  

通过排查问题后得出造成此类问题的原因是,项目的一个模块在批量导入数据,程序需要New一个很大的对象,GC发现内存不够后,对内存进行回收,但是发现回收后的内存还不能满足大对象的需要。应此造成了内存溢出。

解决方案:调大Weblogic的启动内存即可。

阅读全文
0 0
原创粉丝点击