新增导出功能发版后出现生产导出服务内存只增不减,最后导致内存溢出宕机,每次这种情况出现在月底,报表导出数据过多。后面查资料发现使用HSSFWorkbook是将list数据存在内存生成的excel,会导致内存溢出,可将HSSFWorkbook 替换成SXSSFWorkbook。SXSSFWorkbook会将数据存在磁盘中,然后将数据写入到excel中,贴上部分代码:
改之前:
Workbook workbook = null;
if (fileType == ExcelType.XLS) {
workbook = new HSSFWorkbook();
} else if (fileType == ExcelType.XLSX) {
workbook = new XSSFWorkbook();
} else if (fileType == ExcelType.SXLSX) {
workbook = new SXSSFWorkbook(500);
}
改后:
if (fileType == ExcelType.XLS) {
workbook = new HSSFWorkbook();
} else if (fileType == ExcelType.XLSX) {
// 这里将原来的XSSFWorkbook 替换成了 SXSSFWorkbook
XSSFWorkbook sheets = new XSSFWorkbook();
workbook = new SXSSFWorkbook(sheets,500);
} else if (fileType == ExcelType.SXLSX) {
workbook = new SXSSFWorkbook(500);
}
上面 new SXSSFWorkbook(sheets,500); 表示导出数据超过500条,多余的数据会生成临时文件存在磁盘中,在本地测试过程中在我在C:\Users\cd\AppData\Local\Temp\poifiles找到了临时文件
![](https://img-blog.csdnimg.cn/img_convert/f5870b22f362412bba90f9c87b0a7ec2.png)
测试过程中我在 workbook.write(outputStream);之前打了断点,write之前 文件是有值的,
![](https://img-blog.csdnimg.cn/img_convert/10d80af9f772c97e3db918e8c543e340.png)
调用workbook.write(outputStream); 会将临时文件清除
贴上部分修改代码:
![](https://img-blog.csdnimg.cn/img_convert/d6f08bab1592d6ef9959f355ade37b70.png)