Exporting a Confluence page or space as PDF errors out with "We couldn't complete your export. There are too many concurrent exports running on this node"

Still need help?

The Atlassian Community is here for you.

Ask the community

Platform Notice: Data Center Only - This article only applies to Atlassian products on the Data Center platform.

Note that this KB was created for the Data Center version of the product. Data Center KBs for non-Data-Center-specific features may also work for Server versions of the product, however they have not been tested. Support for Server* products ended on February 15th 2024. If you are running a Server product, you can visit the Atlassian Server end of support announcement to review your migration options.

*Except Fisheye and Crucible

Summary

PDF export errors out with the following error message "We couldn't complete your export. There are too many concurrent exports running on this node":

PDF export is a heavy task that may impact the application performance and even lead it to an outage. To prevent this, we limited the threads for this task to the number of CPU cores available in the server hosting Confluence. If you see this error message, this means that you hit this limit, waiting for the previous exports to complete will release the threads to be used by new export requests.

In this KB, we mention a problem that may happen where the threads are not being released after finishing the PDF export and only a restart will help. This problem may affect only one node and restarting it will release the threads.

Environment

This problem was identified in Confluence Data Center version 7.3.5. It could also affect other versions of Confluence.

Diagnosis

Aside from the error in the UI, you may find the following error in the atlassian-confluence.log file:

atlassian-confluence.log
2021-02-23 13:32:12,575 ERROR [http-nio-8090-exec-62] [atlassian.confluence.servlet.ConfluenceServletDispatcher] sendError Could not execute action
 -- url: /spaces/flyingpdf/pdfpageexport.action | traceId: 23ab1ca609f89aee | userName: test | referer: https://confluence.pdftest/display/pdftest/PDF+TEST
java.lang.RuntimeException: We couldn't complete your export. There are too many concurrent exports running on this node

If you generate thread dumps, you may identify the following PDF export thread:

"http-nio-8090-exec-28" #3231 daemon prio=5 os_prio=0 tid=0x00007fd32c2ce800 nid=0x2c05 runnable [0x00007fd27ebe1000]
   java.lang.Thread.State: RUNNABLE
	...
	at com.atlassian.confluence.extra.flyingpdf.impl.FlyingSaucerXmlToPdfConverter.convertXhtmlToPdf(FlyingSaucerXmlToPdfConverter.java:107)
	at com.atlassian.confluence.extra.flyingpdf.impl.FlyingSaucerXmlToPdfConverter.convertXhtmlToPdf(FlyingSaucerXmlToPdfConverter.java:75)
	at com.atlassian.confluence.extra.flyingpdf.impl.InternalPdfExporterService.doCreatePdfForPage(InternalPdfExporterService.java:132)
	at com.atlassian.confluence.extra.flyingpdf.impl.InternalPdfExporterService.createPdfForPage(InternalPdfExporterService.java:100)
	at com.atlassian.confluence.extra.flyingpdf.impl.DelegatingPdfExporterService.createPdfForPage(DelegatingPdfExporterService.java:54)
	at com.atlassian.confluence.extra.flyingpdf.impl.DiagnosticPdfExporterService.createPdfForPage(DiagnosticPdfExporterService.java:88)
	at com.atlassian.confluence.extra.flyingpdf.impl.ExportPageAsPdfAction.doExecute(ExportPageAsPdfAction.java:36)
	at com.atlassian.confluence.extra.flyingpdf.impl.ExportPageAsPdfAction$$Lambda$2405/1155088221.run(Unknown Source)
	at com.atlassian.confluence.extra.flyingpdf.impl.PdfExportSemaphore.run(PdfExportSemaphore.java:28)
	at com.atlassian.confluence.extra.flyingpdf.impl.ExportPageAsPdfAction.execute(ExportPageAsPdfAction.java:29)

If you hit the error in the node and no further PDF export attempts can be made (after waiting for minutes/hours), check the thread dumps and look if you have the same number of threads running as per CPU cores. If it's the same and restarting the node helps but the issue eventually happens again, then this KB should be considered.

Cause

The root cause is unknown at the moment, the threads are running indefinitely after we reach the maximum allowed threads for this task. 

If a root cause is identified, it will be added to this article.

Solution

Java handles these threads and we recommend keeping Java updated. Check our Supported Platforms page to verify which Java version is supported.

You may download either AdoptOpenJDK or Oracle Java with the links below:

If you installed Confluence using the installer option, you may either upgrade Confluence or install Java on the server and change the one used by Confluence (bundled) to the system java.

Last modified on Apr 7, 2022

Was this helpful?

Yes
No
Provide feedback about this article
Powered by Confluence and Scroll Viewport.