Configuring a database query timeout

Still need help?

The Atlassian Community is here for you.

Ask the community

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

Note that this knowledge base article was created for the Data Center version of the product. Data Center knowledge base articles 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

Problem

If database queries are taking too long to perform, and your application is becoming unresponsive, you can configure a timeout for database queries.

Cause

There is no default timeout in Confluence.

Resolution

If you are using PostgreSQL with driver version 8.3 or later Do Not set a query timeout as described below, as it will cause a SEVERE error and prevent Confluence from starting.

You will need to reapply these changes when upgrading Confluence, as the original databaseSubsystemContext.xml file changes from version to version.

To configure a database query timeout, do the following on your test server:

  1. Shut down Confluence.
  2. Extract databaseSubsystemContext.xml from the confluence-x.x.x.jar that is in confluence/WEB-INF/lib/, and put a copy in confluence/WEB-INF/classes/. See Editing files within .jar archives.
  3. Edit confluence/WEB-INF/classes/databaseSubsystemContext.xml to add the defaultTimeout property to the "transactionManager" bean:

    <bean id="transactionManager" class="org.springframework.orm.hibernate.HibernateTransactionManager">
        <property name="sessionFactory">
            <ref bean="sessionFactory"/>
        </property>
        <property name="defaultTimeout" value="120"/>
    </bean>
    

    The timeout is measured in seconds and will forcibly abort queries that take longer than this. In some cases, these errors are not handled gracefully by Confluence and will result in the user seeing the Confluence error page.

  4. Start Confluence.

Once the timeout is working properly in your test environment, migrate the configuration change to your production Confluence environment.

Additional Information

Last modified on Jan 3, 2025

Was this helpful?

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