-
访问接口项目报错
在网上查找了相关资料,问题解释如下
问题产生原因:
根据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%的堆空间时会报这个错误。处理方法
- 在jvm启动参数中添加
-XX:-UseGCOverheadLimit
,该参数在JDK6中默认启用("-XX:+UseGCOverheadLimit")。但是生产环境用的是jdk8,而且,使用的是tomcat作为java容器
调整后的生产环境中使用的参数为:
vim bin/catalina.sh
JAVA_OPTS="-Xms512m -Xmx512m -Xmn300m -Xss512K \
-XX:MetaspaceSize=512m -XX:MaxMetaspaceSize=1024m \
-XX:-UseGCOverheadLimit -XX:+UseConcMarkSweepGC"
然后重启tomcat
2.检查是否有使用了大量内存的代码或死循环
比如,无限制的new对象
- 使用jstat命令监控gc行为是否正常
jstat监控gc的命令格式为:
jstat -gcutil [-t] [-h<lines>] <vmid> [<interval> [<count>]]
vmid为JVM进程id,可以用ps -ef 或 jps -lv命令查找。
以下命令为每1秒钟输出一次gc状态,共输入5次
sudo jps -lv
31465 org.apache.catalina.startup.Bootstrap -Djava.util.logging.config.file=/app/tomcat-app-interface/conf/logging.properties -Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager -Xms512m -Xmx512m -Xmn300m -Xss512K -XX:MetaspaceSize=512m -XX:MaxMetaspaceSize=1024m -XX:-UseGCOverheadLimit -XX:+UseConcMarkSweepGC -Dfile.encoding=UTF-8 -Djava.endorsed.dirs=/app/tomcat-app-interface/endorsed -Dcatalina.base=/app/tomcat-app-interface -Dcatalina.home=/app/tomcat-app-interface -Djava.io.tmpdir=/app/tomcat-app-interface/temp
sudo jstat -gcutil 31465 1000 5
S0 S1 E O M CCS YGC YGCT FGC FGCT GCT
100.00 0.00 21.68 54.20 87.29 68.03 130 3.482 78 2.129 5.611
100.00 0.00 43.13 54.20 87.29 68.03 130 3.482 78 2.129 5.611
100.00 0.00 43.13 54.20 87.29 68.03 130 3.482 78 2.129 5.611
100.00 0.00 43.13 54.20 87.29 68.03 130 3.482 78 2.129 5.611
100.00 0.00 51.76 54.20 87.29 68.03 130 3.482 78 2.129 5.611
经过一段时间的观察,没有再出现该异常。
jstat-----使用参考