以JVM内存设置为512M的服务器为例子,假设并发量为1000,用户讲求的报表为200单元格(差不多为一张A4纸的报表),不管是图片还是文本,我们以一个单元格平均为1.2K计算,可以得出报表系统的内存使用量为:
1000*200*1.2k/1024k=234.375M
根据以上计算,我们在实际生产系统中,建议:
cachedReportTimeout设置成60分钟,用户数据量大的情况下,减少报表缓存时间。
alwaysReloadDefine设置为no,开启缓存,这样客户在翻页时,不再与数据库交互,减轻数据库服务器的负担。同时在tag标签中把useCache设置为yes,而timeout可以根据自己的实时要求进行设置,如果数据一直都不会变的话,建议设置为-1 。
maxConcurrentForReport为1000,这是并发量
maxWaitForReport设置为2000
maxWaitTimeForReport设置为10秒钟,10秒内得不到响应,用户需要再次请求
maxCellNum,在内存中,同时计算的单元格数量建议为200单元格*50页=10000格
1000*200*1.2k/1024k=234.375M
根据以上计算,我们在实际生产系统中,建议:
cachedReportTimeout设置成60分钟,用户数据量大的情况下,减少报表缓存时间。
alwaysReloadDefine设置为no,开启缓存,这样客户在翻页时,不再与数据库交互,减轻数据库服务器的负担。同时在tag标签中把useCache设置为yes,而timeout可以根据自己的实时要求进行设置,如果数据一直都不会变的话,建议设置为-1 。
maxConcurrentForReport为1000,这是并发量
maxWaitForReport设置为2000
maxWaitTimeForReport设置为10秒钟,10秒内得不到响应,用户需要再次请求
maxCellNum,在内存中,同时计算的单元格数量建议为200单元格*50页=10000格