背景
生产项目为java web项目,后台有多个定时任务处理数据,于2015年上线,至出现问题时已平稳运行5年,中途未出现内存溢出导致系统卡死的情况,某一天发现数据处理缓慢,连接到应用服务器(linux),监控日志发现应用报错如下:OutOfMemoryError: Java heap space
问题定位
1、执行top命令,查看java应用内存占用情况
2、导出jvm内存文件 jmap -dump:format=b,file=heap.bin pid
3、导出内存文件到本地,打开eclipse——》File——》Open File…(需安装eclipse memory analyzer插件,安装方法可百度),打开内存文件
然后就可以看到jvm内存相关的统计信息,如下:
可以看出内存中有一个1.4G的大对象,这块是有问题的,继续分析:
最后找到了导致产生大对象的类及方法,手动执行该方法的查询数据库语句,竟然一次查询出了超过300w条数据到内存,至此,问题找到
解决方法
产生问题的原因是一次加载过多的对象到内存,修改代码查询条件,每次只查询200条数据,完美解决