Страница 1 из 1

OutOfMemoryException при экспорте большого PDF

Добавлено: 23 ноя 2024, 13:43
grayroof
Добрый день!
Мы формируем платежные документы в виде PDF
при формировании PDF на 2000 страниц, наше приложение падает с ошибкой переполнения heap (OutOfMemoryException). На данный момент ограничение стоит в 8Гб.
Подскажите, пожалуйста, какие требования к серверу, который делает эту операцию? Сколько необходимо памяти для реализации нашей задачи?

Шаблон отчета во вложении. Возможно, вы сможете предложить альтернативную компоновку для менее ресурсоемкого экспорта в PDF. Или, быть может, предложите более оптимальный источник (на данный момент мы используем json, который формирует другой сервис).

код, выполняющий экспорт:

report = StiSerializeManager.deserializeReport(reportStream);
report.getDictionary().getDatabases().clear();
report.getDictionary().getDatabases().add(jsonDatabase);
report.setCalculationMode(StiCalculationMode.Interpretation);
report.Render(false);
report.exportDocument(StiExportFormat.Pdf, exportService, file, exportSettings, null);

библиотека: 'com.stimulsoft:stimulsoft-reports-libs:2024.2.2'

кстати, обратили внимание на то, что после генерации файла, СтимулСофт не освобождает неиспользуемую память. Нам приходится использовать напрямую сборщик мусора (System.gc()), что является плохой практикой. Ведутся ли в этом направлении какие-то работы, возможны ли оптимизации в ближайших релизах?

Спасибо.

С уважением, Маргарита

Re: OutOfMemoryException при экспорте большого PDF

Добавлено: 25 ноя 2024, 12:56
Vadim
Здравствуйте.

Вы можете установить оптимизацию по памяти - отчет будет генерироваться медленнее, но расходовать меньше оперативной памяти.
Используйте свойство report.setReportCacheMode(StiReportCacheMode.On или StiReportCacheMode.Auto)

Re: OutOfMemoryException при экспорте большого PDF

Добавлено: 28 ноя 2024, 08:51
grayroof
Мы попробовали StiReportCacheMode.On

памяти действительно потребляет меньше. Однако теперь пишет ошибку: Unable to access image with URL: resource://Image2
и не выводит картинку в футере сформированного PDF. файл с изображением в ресурсах имеется, и если отключить кэшмод, то изображение прекрасно выводится в футере документа

для кэшмода как-то по-другому нужно ресурс для изображения указывать?

Re: OutOfMemoryException при экспорте большого PDF

Добавлено: 29 ноя 2024, 23:10
Aleksey
Здравствуйте,

Нужно дополнительное время для анализа проблемы.

Спасибо.

Re: OutOfMemoryException при экспорте большого PDF

Добавлено: 02 дек 2024, 11:15
Vadim
Здравствуйте.
Пришлите пожалуйста полный стек ошибки.

Re: OutOfMemoryException при экспорте большого PDF

Добавлено: 05 дек 2024, 12:41
grayroof
Добрый день!
строка, содержащая ошибку:
{"@timestamp":"2024-12-05T11:19:07.26807989+03:00","@version":"1","message":"Unable to access image with URL: resource://logo_backspark","logger_name":"com.stimulsoft.report.components.simplecomponents.StiImage","thread_name":"batch_thread-2","level":"WARN","level_value":30000}

это все, что выдает сервис. Возможно, требуется подключить детальное логирование?

во вложении находятся три файла: 2 файла с логами в разном формате и источник в формате json для документа в 150стр. Было зафиксировано, что проблема возникает именно при экспорте большого объема данных.
Спасибо.

Re: OutOfMemoryException при экспорте большого PDF

Добавлено: 06 дек 2024, 12:48
Vadim
Здравствуйте,

Нужно дополнительное время для анализа проблемы.

Спасибо.

Re: OutOfMemoryException при экспорте большого PDF

Добавлено: 11 дек 2024, 16:30
Vadim
Здравствуйте.

Будет исправлено с версией 2025.1.1

Re: OutOfMemoryException при экспорте большого PDF

Добавлено: 11 дек 2024, 20:28
grayroof
Большое спасибо!

Re: OutOfMemoryException при экспорте большого PDF

Добавлено: 12 дек 2024, 02:51
Aleksey
Здравствуйте,

Пожалуйста. Билд будет на следующей неделе.