问题处理一例:GC overhead limit exceeded

Tomcat Log 中有以下异常

May 31, 2012 11:54:25 AM org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler process
SEVERE: Error reading request, ignored
java.lang.OutOfMemoryError: GC overhead limit exceeded
Exception in thread "http-80-43" java.lang.NullPointerException
        at java.util.concurrent.ConcurrentLinkedQueue.offer(ConcurrentLinkedQueue.java:273)
        at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler$1.offer(Http11Protocol.java:537)
        at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler$1.offer(Http11Protocol.java:554)
        at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:618)
        at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:489)
        at java.lang.Thread.run(Thread.java:619)
May 31, 2012 11:55:46 AM org.apache.coyote.http11.Http11Processor process
SEVERE: Error processing request
java.lang.OutOfMemoryError: GC overhead limit exceeded
May 31, 2012 11:56:58 AM org.apache.catalina.core.ContainerBase$ContainerBackgroundProcessor processChildren

 

问题产生原因:

根据sun的说法: "if too much time is being spent in garbage collection: if more than 98% of the total time is spent in garbage collection and less than 2% of the heap is recovered, an OutOfMemoryError will be thrown."

jvm gc行为中超过98%以上的时间去释放小于2%的堆空间时会报这个错误。

 

处理方法:

1. 在jvm启动参数中添加 "-XX:-UseGCOverheadLimit",该参数在JDK6中默认启用("-XX:+UseGCOverheadLimit")。

  调整后的生产环境中使用的参数为:   

JAVA_OPTS='-Xms512m -Xmx4096m -XX:MaxPermSize=128m -XX:-UseGCOverheadLimit -XX:+UseConcMarkSweepGC'

2. 检查是否有使用了大量内存的代码或死循环

3. 使用jstat命令监控gc行为是否正常

  jstat监控gc的命令格式为: 

  jstat -gcutil [-t] [-h<lines>] <vmid> [<interval> [<count>]] 

  vmid为JVM进程id,可以用ps -ef 或 jps -lv命令查找。

  以下命令为每1秒钟输出一次gc状态,共输入5次

[root@localhost bin]# jstat -gcutil 7675 1000 5
  S0     S1     E      O      P     YGC     YGCT    FGC    FGCT     GCT   
  0.00   0.00  41.98   9.53  99.26    230    0.466   186   24.691   25.156
  0.00   0.00  41.98   9.53  99.26    230    0.466   186   24.691   25.156
  0.00   0.00  41.98   9.53  99.26    230    0.466   186   24.691   25.156
  0.00   0.00  41.98   9.53  99.26    230    0.466   186   24.691   25.156
  0.00   0.00  41.98   9.53  99.26    230    0.466   186   24.691   25.156

  经过一段时间的观察,没有再出现该异常

参考:

Java 6 JVM参数选项大全(中文版)

jstat - Java Virtual Machine Statistics Monitoring Tool

转载于:https://www.cnblogs.com/esky2000/archive/2012/06/06/2537791.html

引用\[1\]:在Java编程中,当出现"java.lang.OutOfMemoryError: GC overhead limit exceeded"错误时,意味着Java虚拟机(JVM)花费了太多的时间在垃圾回收上,但回收的内存却非常有限。这个错误通常是由于堆内存设置过小导致的。\[3\]当垃圾回收占用了超过98%的时间,并且回收的堆内存不到2%时,就会抛出这个异常。这种情况下,JVM会认为垃圾回收的效果不好,进而抛出异常。引用\[2\]中提到了解决这个问题的方法。一种解决方法是增加JVM的堆内存大小,可以通过修改JVM的启动参数来实现。另一种解决方法是检查代码中是否存在内存泄漏或者过度使用内存的情况,例如循环引用、大量的对象创建等。通过优化代码,可以减少内存的占用,从而避免这个错误的发生。所以,当出现"java.lang.OutOfMemoryError: GC overhead limit exceeded"错误时,可以考虑增加堆内存大小或者优化代码来解决这个问题。 #### 引用[.reference_title] - *1* *3* [java.lang.OutOfMemoryError: GC overhead limit exceeded问题分析及解决](https://blog.csdn.net/whc888666/article/details/128496598)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [Java IDEA pom 报错java.lang.OutOfMemoryError: GC overhead limit exceeded 基本所有依赖都报错(除了JDK...](https://blog.csdn.net/weixin_45268865/article/details/123839339)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值