最初的配置:-Xms1024m -Xmx1024m -XX:PermSize=1024M -XX:MaxPermSize=1024m,在使用的过程中出现了内存溢出,日志中打出了**.hprof文件,根据个人经验怀疑估计是内存不够导致的,然后增加一倍的配置:-Xms2048m -Xmx2048m -XX:PermSize=2048M -XX:MaxPermSize=2048m 依然没有解决问题。
于是决定进行分析打出来的文件,具体步骤如下:
导出来以后需要利用Eclipse Memory Analyzer Tool(MAT)分析内存泄漏,MAT工具大家可以自行在百度上搜索下载即可.
简单看一下这个工具的用途:
经过分析该类递归很多次,后面发现是缓存导致
顺便把内存也调大一倍:
-Xms4048m -Xmx4048m -XX:PermSize=4048M -XX:MaxPermSize=4048m
调整jpa的默认缓存大小,默认是2G,所以随着时间的推移,很容易出现内存溢出,因此调整如下:
jpa:
properties:
bibernate:
query:
plan_cache_max_size: 64
plan_parameter_metadata_max_size: 32
plan_cache_max_soft_references: 1024
plan_cache_max_strong_references: 64
解决问题