记一次Full GC问题的排查

今天看到监控平台显示项目的Full GC次数过多,查看了一下监控曲线,如下图,发现发生的时间点基本上都是在上午十点之后,到下午五点。


分析:考虑到业务形态,开始初步怀疑是访问人数增多引起的虚拟机内存不足,后来继续看监控指标找线索,发现如下图的监控曲线,当Young GC时,Old区的已使用空间并没有发生明显变化,而且剩余空间也非常大,所以通过这个分析发生Full GC的原因并不是虚拟机自动回收内存导致,很可能是在代码中存在System.gc(),所导致的Full GC。

 在项目中搜索,发现jxl.jar中存在System.gc代码,这个jar的使用跟项目中需要进行Excel操作的需求有关,逐级跟踪到调用接口,找到调用接口之后,在监控平台上查看此接口的访问情况,发现确实是在发生Full GC时的时间点与接口访问的时间点相同,也就印证了我们的猜测。


解决:找到了问题之后,解决起来就相对简单了,经过查看源码发现,初始化Excel操作类时提供了两个构造函数,一般都是使用默认的,这次我们只需要把相关的配置参数传给构造函数就行。

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 作者:一字马胡 转载标志 【2017-11-12】 更新日志 日期更新内容备注 2017-11-12新建文章初版 ...
    beneke阅读 2,251评论 0 7
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,246评论 19 139
  • 1.什么是垃圾回收? 垃圾回收(Garbage Collection)是Java虚拟机(JVM)垃圾回收器提供...
    简欲明心阅读 90,035评论 17 311
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 174,385评论 25 709
  • 小明告诉我,昨天为了给儿子报培训班的事情,夫妻俩又开战了。 小明老婆说,儿子班上的那些同学,家长们都在给孩子...
    苏州的蔷薇花开阅读 398评论 5 3