一次JVM内存调优过程

项目中,有个同事写的JOB,使用到查询数据库大量历史协议数据(大概300W左右),由于对存放数据的list或map没有做“用完即时声明释放”。

导致此Jar部署在windows service后,进程的内存资源一直居高不下,而且多次执行后,JVM内存终于增长超过最大JVM内存设置max=3GB,

从而导致程序报错“内存溢出OutOfMemoryException”提示。

 

解决思路如下:

1. 修改代码中:大数据的list和map的用完之后,增加声明释放资源代码:list.clear()和list =null;

2. 修改jvm命令:增加jvm管理GC回收策略的参数,如:-Xmx2048m -XX:MaxGCPauseMillis=100 -XX:+UseParallelOldGC -XX:+UseParallelGC

 

然后,删除之前注册的windows service (寄宿jar的java程序),重新注册和启动jar的windows service服务,测试结果发现:

此JOB的jvm内存使用就会自动在list和map使用完毕之后,快速回收占用的内存资源。

并且不管多次运行JOB,也不会提示内存溢出的异常。

 

图1:修改前,每次执行完JOB,其进程的内存资源一直没有释放,如下图

 

图2:修改后,每次执行完JOB,其进程的内存资源会快速释放,如下图

一次JVM内存调优过程_第1张图片

 

你可能感兴趣的:(一次JVM内存调优过程)