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

Обсуждение Stimulsoft Reports.JAVA
Ответить
grayroof
Сообщения: 4
Зарегистрирован: 23 май 2024, 08:28

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

Сообщение 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()), что является плохой практикой. Ведутся ли в этом направлении какие-то работы, возможны ли оптимизации в ближайших релизах?

Спасибо.

С уважением, Маргарита
Вложения
Report_UPD.mrt
(685.07 КБ) 67 скачиваний
Report_short_PD.mrt
(669.03 КБ) 66 скачиваний
С уважением, Маргарита Шаймиева
Vadim
Сообщения: 113
Зарегистрирован: 04 апр 2013, 12:26

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

Сообщение Vadim »

Здравствуйте.

Вы можете установить оптимизацию по памяти - отчет будет генерироваться медленнее, но расходовать меньше оперативной памяти.
Используйте свойство report.setReportCacheMode(StiReportCacheMode.On или StiReportCacheMode.Auto)
grayroof
Сообщения: 4
Зарегистрирован: 23 май 2024, 08:28

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

Сообщение grayroof »

Мы попробовали StiReportCacheMode.On

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

для кэшмода как-то по-другому нужно ресурс для изображения указывать?
С уважением, Маргарита Шаймиева
Aleksey
Сообщения: 2923
Зарегистрирован: 22 апр 2010, 06:57

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

Сообщение Aleksey »

Здравствуйте,

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

Спасибо.
Vadim
Сообщения: 113
Зарегистрирован: 04 апр 2013, 12:26

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

Сообщение Vadim »

Здравствуйте.
Пришлите пожалуйста полный стек ошибки.
grayroof
Сообщения: 4
Зарегистрирован: 23 май 2024, 08:28

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

Сообщение 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стр. Было зафиксировано, что проблема возникает именно при экспорте большого объема данных.
Спасибо.
Вложения
ua_pack_002_150.json
проблема возникает при экспорте большого числа страниц. приложен источник на 150 стр
(671.32 КБ) 40 скачиваний
Logs-data-2024-12-05 12_24_50_logo.csv
логи в тексте с разделителями
(1.08 МБ) 40 скачиваний
Logs-data-2024-12-05 12_24_50_logo.xls
логи в формате эксель
(1.14 МБ) 41 скачивание
С уважением, Маргарита Шаймиева
Vadim
Сообщения: 113
Зарегистрирован: 04 апр 2013, 12:26

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

Сообщение Vadim »

Здравствуйте,

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

Спасибо.
Vadim
Сообщения: 113
Зарегистрирован: 04 апр 2013, 12:26

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

Сообщение Vadim »

Здравствуйте.

Будет исправлено с версией 2025.1.1
grayroof
Сообщения: 4
Зарегистрирован: 23 май 2024, 08:28

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

Сообщение grayroof »

Большое спасибо!
С уважением, Маргарита Шаймиева
Aleksey
Сообщения: 2923
Зарегистрирован: 22 апр 2010, 06:57

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

Сообщение Aleksey »

Здравствуйте,

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