2

我正在导出一个非常大的碧玉报告(大约 20000 页)。为此,为了避免内存不足错误,正如不同网站所建议的那样,我正在使用 JRSwapFileVirtualize,如下所示:

virtualizer = new JRSwapFileVirtualizer(1000, new JRSwapFile(reportFilePath, 2048, 1024), true);
parameters.put(JRParameter.REPORT_VIRTUALIZER, virtualizer);
.
.
JasperPrint print = JasperFillManager.fillReport(report, parameters, list);
virtualizer.cleanup();

我的问题是:

1)我将maxSize配置为1000,20000页的报表可以吗?

2)我在方法调用“fillReport”后立即清理虚拟器。是否正确,或者我需要在将报告导出到 XLS 后清理虚拟器?

3)无论如何在导出报告后清理虚拟器,对我有帮助吗?

4) 创建 JasperPrint 对象,逻辑写在服务器端。导出报表逻辑,是用java客户端写的。如果我应该清理虚拟器,在导出报告后,我该如何处理这种情况?因为在这种情况下,我需要在服务器端创建此虚拟器的静态对象(因为 JRSwapFileVirtualizer 不可序列化,因此我无法在服务器和客户端之间创建并传递它),然后在导出后再次调用服务器端方法进行清理虚拟机。我在想创建静态对象是有风险的,因为如果对服务器端逻辑进行多次调用,那么虚拟器静态对象将保存对最新调用创建的交换文件的引用,因此在清理之后,以前的交换文件可能不会被删除.

我找到了有关此主题的更多信息:在 jasper 提供的使用虚拟器的示例中,他们仅在调用 common export 时清理虚拟器,它导出了多种类型的文件。当他们只导出单一类型的报告时,他们没有调用清理:

else if (TASK_CSV.equals(taskName))
{
    exportCSV(jasperPrint);
}       
else if (TASK_EXPORT.equals(taskName))
{
    exportPDF(jasperPrint);
    exportXML(jasperPrint, false);
    exportHTML(jasperPrint);
    exportCSV(jasperPrint);

    // manually cleaning up
    virtualizer.cleanup();
}

他们也没有在这个例子中提到 XLS 导出。我找到了另一个链接,该人遇到了同样的问题,但也没有提到解决方案:

http://www.jasperforge.org/plugins/espforum/view.php?group_id=102&forumid=103&topicid=95689

此链接还说我们可以改用 JRXlsxExporter 。但是 JRXlsxExporter 只导出 excel 2007 格式而不是 2003 格式。

我正在使用 JExcelApiExporter.exportReport() 将报告导出到 XLS,对于大型报告它不起作用。请帮我解决这个问题。任何小的提示或建议都是可以理解的。如果您需要更多信息,请告诉我。谢谢。

4

2 回答 2

1

1.对于您的第一个问题,这实际上取决于您为报告生成应用程序提供了多少堆大小。尝试试错方案,您将获得准确的尺寸

对于你的第二个问题

2.根据您的第一个代码片段,您正在填写报告并立即在虚拟器上应用清理。因此,即使您创建了报告,清理后您的交换文件也将被销毁并且因为您的数据。-- 一旦确认报告数据使用完成,您应该在虚拟器上应用清理。所以在这种情况下,在导出为特定格式后。

3.cleanup 是立即销毁交换文件。因此,如果您不打算在导出后重用报告,则应用清理是最好的主意。注意:即使您没有明确地清理它,垃圾收集器也会在处理 jasperPrint 时将其销毁。

你的第四点对我来说很不清楚,你是说 jasperPrint 一直在服务器端创建......并且导出逻辑是在客户端编写的......导出逻辑如何在客户端没有参考 JasperPrint,哪个在服务器端....??1!!

于 2012-08-06T05:13:34.510 回答
1

好的..当您应用fillReport时,您的所有数据集(记录)将保存在jvm(堆空间)中,导出器将在导出为任何格式时使用它。

在这里,如果您的数据集大小比 jvm 的大小增加,您将被 outOfMemeryError 挂起,因此 virtualizer(FileVirtualizer & swapfile) 将帮助您将这些数据集存储到文件中,而不是使用 jvm 内存(最终它使用序列化来存储数据集归档)。

关于文章:这是正确的,它在填充报告时使用:因此,在填充(调用 fillReport)时将一些对象存储在内存中,这些对象需要即时访问并使用虚拟器保留到文件中。因此,当您尝试访问剩余记录时(使用导出器选项进行分页),JasperPrint 将从文件中获取这些记录,并根据需要交换未使用的页面。

在这里,我只说 abt JRFileVirtualizer JRSwapFileVirtualizer。在 JRGzipVirtualizer 的情况下,存储将在内存中但压缩格式。如果您没有直接访问磁盘的权限,将使用哪个。

于 2012-08-08T08:51:31.657 回答