项目中的报表一运行就报内存溢出(birt报表),是哪里配置错了?
2015-06-06
birt没用过,一直用的都是finereport,觉得挺好用的,你可以试试,类似的问题在finereport中是这样解决的:
1. 问题描述
当从数据库中查询大量的数据,每个模板取出来几百万条数据,或者是频繁的刷新项目、模板时就会占用Java虚拟机JVM的大量内存,超过内存就会出现报java.lang.OutOfMemoryError:Java heap space内存一处的错误,具体报错如下:
2. 原因
由于服务器的JVM不够用而抛出的错误,JVM在启动的时候会自动设置Heap size的值,初始空间(即-Xms)是物理内存的1/64,最大空间(-Xmx)是物理内存的1/4。所以可以根据自己的情况进行修改JVM的-Xmn -Xms -Xmx等选项。
2.1 内存大小设置
当Heap Size设置偏小,除了报异常信息外,还会发现执行报表的速度变慢了。
Heap Size最大不要超过可用物理内存的80%,一般的要将-Xms和-Xmx选项设置为相同,而-Xmn为1/4的-Xmx值。Heap size的 -Xms -Xmn 设置不要超出物理内存的大小。否则会提示“Error occurred during initialization of VM Could not reserve enough space for object heap”
3. 解决方案
3.1 调大服务器的内存
下面我们以tomcat为例,来查看下如何修改内存大小。
修改服务器的内存溢出在TOMCAT_HOME\bin\catalina.bat 中添如下代码:
set JAVA_OPTS= -Xmx1024M -Xms512M -XX:MaxPermSize=256m
或者在开始程序 tomcat目录下面的Configure Tomat打开
选择Java设置内存大小
其他服务器的内存修改可以参考服务器内存修改文档。
3.2 启用磁盘缓存
我们默认使用的是内存缓存,就是取出的数据全部放在服务器内存中,此时若数据量大的情况下就很可能会导致内存不够用,改为磁盘缓存,就是将取出的数据部分放在内存中,部分放在磁盘中,这样可以减少服务器内存占用,但是从磁盘中读取数据会造成取数效率下降,增长时间的。
具体的操作可查看数据集缓存与共享的缓存至磁盘小节。
2015-05-21