What data should be provided to Atlassian on support tickets for an effective initial troubleshooting
Atlassian Knowledge Base
- Application Links Troubleshooting Guide
- Database Troubleshooting and How-to Guides
- Best practices for performance troubleshooting tools
- SSL/TLS Troubleshooting
- Cross Product Knowledge
- Proxying Atlassian Server applications
- Atlassian Account Troubleshooting
- Mapping Web Resources to Code
- Subscribe to Proactive Announcements
- How to capture HTTP traffic using Wireshark, Fiddler, or tcpdump
- Cross Site Request Forgery (CSRF) protection changes in Atlassian REST
- Purchased Add-ons feature is unavailable
- Single Sign-on Integration with Atlassian products
- Troubleshooting Services
- Test disk access speed for a Java application
- User Management Troubleshooting and How-To Guides
- Atlassian login issues
- JQL with OR results in error.
- How to set the timezone for the Java environment
- Websudo is disabled after migration from JIRA cloud to JIRA server
- Health Check: Lucene index files location
- Health Check: Thread Limit
- Editor Window is Small After Upgrading where as the preview is Normal window size
- Basic authentication fails for outgoing proxy in Java 8u111
- All Atlassian knowledge base articles
- Creating A Jira Administrator That Does Not Count Towards License
- Users are unable to log in to JIRA (LDAP: error code 49, data 52e)
- User unable to login into Crowd after Crowd was upgraded
- How to use the Performance Data Collector
- Ports used by Atlassian Applications
- How to define Xmx based on GC logs
- How to log in to my Atlassian cloud site for the first time
- How to block access to a specific URL at Tomcat
- User-installed apps health check fails in Data Center when configuring CDN
- HTTP2 health check fails in Data Center when configuring CDN
- How to configure Apache for caching and HTTP/2
- How to Unsubscribe from Jira Server or Confluence Server apps on TestFlight (Server and Data Center)
- Unable to synchronize with Active Directory due to SSL requirement (Server and Data Center)
- Jira Align - Jira Connector pages do not load completely
- Jira Align - Work In Process by Value Stream is missing work items
- JVM is not reachable with jstat and jstack
- Data pipeline troubleshooting
- Using JDK 11 to develop apps with the Atlassian SDK is not yet supported
- How to download Atlassian Marketplace apps through the command line
- How to manage named contacts for Atlassian Premier Support (on-premises)
- Bidirectional characters warning in Atlassian products
- FAQ for CVE-2021-42574
- Jira is logging multiple cache flushes in the application logs (Server and Data Center)
- FAQ for CVE-2021-44228, CVE-2021-45046 and CVE-2021-45105
- On-Prem Upgrade Information (March 2022)
- FAQ for CVE-2022-22965
- FAQ for CVE-2022-0540
- Troubleshooting Configure Fields in Jira Server and Data Center
- FAQ for CVE-2022-26134
- How to disable custom Configure Fields in Create Issue screen in Jira Server and Data Center
- FAQ for CVE-2022-26135
- FAQ for CVE-2022-26138
- FAQ for CVE-2022-26136 / CVE-2022-26137
- FAQ for CVE-2022-36804
- Atlassian Authentication App
- FAQ for CVE-2022-43782
- Allowlist URL's for Jira-Slack integration
- FAQ for CVE-2023-22501
- Cannot start Jira over another node via pbrun command (Server and Data Center)
- Attachment health check shows warning message when a custom attachment page is used in Jira Server and Data Center
- FAQ for CVE-2019-13990
- FAQ for CVE-2022-1471
- FAQ for CVE-2023-22515
- FAQ for CVE-2023-22518
- FAQ for CVE-2023-46604
- FAQ for CVE-2023-22523
- FAQ for CVE-2023-22522
- FAQ for CVE-2023-22524
- FAQ for CVE-2023-22527
- Using a temporary license before upgrading to Cloud or Data Center
- Guide for Atlassian Premier Support Named Contacts: On-Premises Product Support Essentials
- What data should be provided to Atlassian on support tickets for an effective initial troubleshooting
On this page
Related content
- No related content found
Platform notice: Server and Data Center only. This article only applies to Atlassian products on the Server and Data Center platforms.
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
Providing relevant information when submitting a support ticket is crucial for effective troubleshooting. Certain data should be gathered even before restarting any nodes or taking similar actions. The relevance of specific data or evidence may vary depending on the symptoms observed.
This article is designed to assist customers by providing an initial overview of the types of information that Atlassian Support typically requires for different symptoms. While additional details may be requested during the triage process, the information outlined here serves as an excellent starting point.
Most symptoms and steps are applicable across various products, with specific instructions for Jira Data Center, Confluence Data Center, Bamboo Data Center, Bitbucket Data Center, and Fisheye and Crucible clearly specified where necessary. Even if an example pertains to one product, it can often be adapted for others, as the principles mainly involve paths or file name conventions.
Quick access to the topics:
- Before restarting a node
- When the product is slow
- When the product is unresponsive
- When the Database has high CPU load or is slow
- When encountering errors while using the product
- When encountering errors while making REST API calls
- Jira: Not sending e-mails or not creating tickets from e-mails (or slow e-mail processing)
- Jira: Replication issues or different data on different nodes
- Bitbucket: Bitbucket process unexpectedly terminated
Environment
Any supported version of the following Data Center products:
- Jira Software
- Jira Service Management
- Confluence
- Bitbucket
- Bamboo
Any supported version of the following Server product:
- Fisheye and Crucible
Solution
Below you will find a detailed breakdown of the symptoms, alongside the most relevant initial data for each one.
Latest "Troubleshooting and Support" app
It is crucial to keep the Troubleshooting and Support app updated to the latest version as frequently as possible. Updates can be easily performed through the product's Manage Apps page.
Atlassian regularly releases new versions of this app, enhancing both the range and quality of troubleshooting data gathered through support zips. For instance, recent updates now include information about the Feature Flags enabled in the instance — data that was previously accessible only through database queries or by requesting specific screenshots from Admin pages.
Before restarting a node
1. Support zip or logs
If you are running the product in a container (such as Docker, Kubernetes, etc) and encounter issues with logs being lost after each restart, you have a few options:
Create a Support Zip through the UI, if it is accessible.
If the UI is not available, you can create a Support Zip using alternative methods, such as:
If neither of the above options is feasible, you can manually zip the contents of the following folders:
<application-local-home>/log(s)
<application-installation-directory>/log(s)
Once you have created the Support Zip or zipped the log(s) folders, be sure to attach them to your support ticket upon creation or immediately afterward. Additionally, inform the support team if you were able to collect the data before the restart.
2. Review the steps from other topics
When restarting the product because of a different symptom (described below), it is essential to gather data related to that specific symptom prior to restarting the node. This ensures that all relevant information is collected for effective troubleshooting and resolution.
When the product is slow
Slowness can be a symptom with various underlying causes. Troubleshooting typically begins by determining whether the issue originates from the "server side," "client side," or the "network."
1. Generating HAR files
Is your operation taking a bit longer to complete in the UI, or is a page loading slowly? If so, capturing a HAR file while you perform the action can be incredibly helpful. To ensure the best results, it's recommended to conduct all browser data captures in an "incognito window" or after clearing all caches, cookies, and site data, followed by restarting the Browser.
The HAR file will provide valuable insights, helping us understand where to direct our attention next: whether it's on the server, network, or client side.
2. Generating thread dumps
Thread dumps are signals emitted to the JVM (Java Virtual Machine), prompting it to "write down" what every thread is doing at that precise moment. This data is invaluable when addressing issues related to "slowness on the server," as it provides insight into what might be causing delays.
It's important to note that thread dumps are most effective when captured at regular intervals, such as "20 times every 3 seconds" (one minute). By examining threads that appear to be "doing the same thing" across multiple "snapshots", we can identify potential slowdowns or bottlenecks in specific areas of execution.
As highlighted in the article, jstack is the preferred method for generating these dumps. If you find yourself without it and need to use kill -3, please rest assured that this action won't stop the product. The kill -3 command simply signals the JVM to produce the thread dumps, and it is not the same as a regular "kill" or "kill -9" command.
Should you opt for kill -3, it will also be necessary to provide a Support Zip that includes "all files" with "no file size limit" selected, or alternatively, you can send the <application-installation-directory>/log(s)/catalina.out file, as this is where the thread dumps are recorded.
3. Generating s heap dump when there are Full GC cycles or OutOfMemoryError (OOM)
If the product is unresponsive or slow due to memory pressure, obtaining a heap dump will be crucial in understanding the root cause.
To investigate potential Full GCs, you can look for the term "Full" in the GC logs, such as <application-local-home>/logs/atlassian-application-gc-*.log. It's helpful to check for any recent timestamps at the beginning of each line, as this can provide valuable context regarding the performance concerns you're experiencing:
grep -a -E -h 'Full.*->' <application-local-home>/logs/*-gc-* -h | sort -nr | uniq | head -100
Or if there are recent OOM (OutOfMemoryError) in the logs, it might be helpful to take a closer look at any recent time entries (beginning of each line that has it):
grep -a -h "java\.lang\.OutOfMemoryError" <application-local-home>/log/atlassian-*.log* -C3
If so, it would be very helpful to generate a heap dump while the issue is occurring:
- Analyze OutofMemory errors in Jira server with heap dumps
- Monitor Memory usage and Garbage Collection in Bamboo
If you already have the options -XX:+HeapDumpOnOutOfMemoryError and -XX:HeapDumpPath=... set for the JVM, please take a moment to check if there’s any recent (and corresponding with the incident time) .hprof file in the folder "HeapDumpPath". If you find one, uploading it would be very beneficial, as these files are generated specifically by the OutOfMemory event and can provide valuable insights.
4. Support zip or logs
Create a Support Zip through the UI, if it is accessible.
If the UI is not available, you can create a Support Zip using alternative methods, such as:
If neither of the above options is feasible, you can manually zip the contents of the following folders:
<application-local-home>/log(s)
<application-installation-directory>/log(s)
Once you have created the Support Zip or zipped the log(s) folders, be sure to attach them to your support ticket upon creation or immediately afterward.
When the product is unresponsive
Unresponsiveness may suggest that the product is either down or operating at such a slow speed that it becomes impractical for use.
1. Confirm if the product is running
On each node of the cluster, check whether the product task or process is currently running. This step is crucial as it will help us understand if it's really down or just terribly slow.
In Linux, for example, this command can be used if executed as root or sudo:
ps -ef | grep -i java
If the product is not running, please start it up and generate a support zip from the affected nodes. Once created, upload these zips to the support request. The support zips will contain historical log data that may be helpful in diagnosing the issue.
Additionally, inform the Support team about the product's downtime and the exact time you restarted it.
2. Refer to the steps from "Product is slow" above
If the product process is currently running, this could indicate a "Product is slow" scenario. Therefore, please refer to the steps outlined in that section instead.
Product specific
3. Remote agent
If you're experiencing issues with your remote agent(s), check whether the agent task or process is currently running.
In Linux, for example, this command can be used if executed as root or sudo:
ps -ef | grep -i java
If the remote agent is not running, please start it up and manually compress the <bamboo-agent-home>/atlassian-bamboo-agent.log files. The logs from the remote agent will include historical data that may be useful for diagnosing the issue. Furthermore, please notify the Support team regarding the agent's downtime and specify the exact time you restarted it.
Once you have zipped the log files, be sure to attach them to your support ticket upon creation or immediately afterward.
When the Database has high CPU load or is slow
1. Database report on top statements
Databases have internal tools for listing statements (queries, updates, etc) that are currently requiring the most CPU, memory, highest frequency or running for a long time.
Please provide the outputs of such commands/tools with the "top offending" statements. This may help support narrow down which part of the product's responsible for those statements and correlate with the other data below.
2. Thread dumps
Thread dumps are signals emitted to the JVM (Java Virtual Machine), prompting it to "write down" what every thread is doing at that precise moment. This data is invaluable when addressing issues related to "slowness on the server," as it provides insight into what might be causing delays.
It's important to note that thread dumps are most effective when captured at regular intervals, such as "20 times every 3 seconds" (one minute). By examining threads that appear to be "doing the same thing" across multiple "snapshots", we can identify potential slowdowns or bottlenecks in specific areas of execution.
As highlighted in the article, jstack is the preferred method for generating these dumps. If you find yourself without it and need to use kill -3, please rest assured that this action won't stop the product. The kill -3 command simply signals the JVM to produce the thread dumps, and it is not the same as a regular "kill" or "kill -9" command.
Should you opt for kill -3, it will also be necessary to provide a Support Zip that includes "all files" with "no file size limit" selected, or alternatively, you can send the <application-installation-directory>/log(s)/catalina.out file, as this is where the thread dumps are recorded.
3. Support Zip
There's not much to collect at this initial moment aside from the above and a support zip from all nodes customized for 3 days, 100 MB limit (or higher), and all files:
Once you have created the Support Zip, be sure to attach it to your support ticket upon creation or immediately afterward. Support may request additional data depending on what the evidence above reveals.
When encountering errors while using the product
This section serves as a comprehensive overview for any operational failures encountered within the product. This includes issues such as difficulties in opening a page, clicking on links, or attempting to edit content.
1. Screenshots of errors and timing
Screenshots can be incredibly helpful for effective troubleshooting. Key elements to capture include the screen being displayed, the error message, and the time of occurrence.
To maximize the utility of your screenshot, ensure it captures the full URL in the browser, the entire product page, and the exact time the issue occurred, along with the corresponding timezone. If necessary, sensitive information can be obscured using an image editor. This comprehensive approach is essential, as a partial view of the page may not provide enough context, while the complete URL and full page will significantly aid in identifying the problem.
2. Generating HAR files
The HAR file contains key information about the requests made and the responses received. The response status codes are important, along with their content when available. To ensure the best results, it's recommended to conduct all browser data captures in an "incognito window" or after clearing all caches, cookies, and site data, followed by restarting the Browser.
Depending on the specific issue, Support may also request a copy of the "Console log" from the browser; however, the HAR file serves as an excellent starting point for troubleshooting.
3. Support zips
There's not much to collect at this initial moment aside from the above and a support zip from all nodes customized for today, no file limit, and all files:
Once you have created the Support Zip, be sure to attach it to your support ticket upon creation or immediately afterward. Support may request additional data depending on what the evidence above reveals.
Product specific
4. Workflow XML
If the error is occurring when creating or changing the status of an Issue (transition), you may also export the respective workflow for that Issue in XML format and upload it to the support ticket:
It is not uncommon for misconfigurations within workflows, as well as faulty validators or post-functions, to lead to errors encountered by end-users.
5. Issue JSON
When encountering an error related to a specific Jira issue (or a group of issues), having access to the issue data and its history is crucial for Support.
To gather this information, please open the following URLs in your browser (be sure to replace JIRA-URL and NOT_OK_ISSUE-99999 with the appropriate values):
https://JIRA-URL/rest/api/latest/issue/NOT_OK_ISSUE-99999?expand=changelog,names
If there's a Jira issue that's working as expected, it can also be beneficial for Support to compare it with the NOT_OK_ISSUE. You can access this data using the link below:
https://JIRA-URL/rest/api/latest/issue/OK_ISSUE-99999?expand=changelog,names
Once you have retrieved the information, save the contents as NOT_OK_ISSUE-99999.json and OK_ISSUE-99999.json, and then upload these files to the support request.
When encountering errors while making REST API calls
The issues we encounter are similar to those seen in the web browser; however, we require slightly different data for resolution.
This article serves as a valuable resource for self-guided troubleshooting. While the title indicates a focus on requests from Jira, it is equally beneficial for addressing requests to Jira as well as to other products.
1. Request attempted, response received, and timestamp
Provide the following information if possible:
Request Details: Include the complete URL, parameters, and any payload data associated with the request. Sensitive information such as passwords or authentication tokens can be redacted for security.
Response Details: Share both the HTTP Response Status Code and the content of the response. If there are any response headers, please include all of them as well.
Timestamp: Indicate the time (and timezone) when the error occurred. This will help us narrow down the logs more effectively.
It is very helpful to replicate the request using tools like Postman or cURL. Remember to include the -D- parameter to print all headers and content, and share that information with Support.
2. Support zips
There's not much to collect at this initial moment aside from the above and a support zip from all nodes customized for today, no file limit, and all files:
Once you have created the Support Zip, be sure to attach it to your support ticket upon creation or immediately afterward. Support may request additional data depending on what the evidence above reveals.
Product specific
3. Workflow XML
If the error is occurring when creating or changing the status of an Issue (transition), you may also export the respective workflow for that Issue in XML format and upload it to the support ticket:
It is not uncommon for misconfigurations within workflows, as well as faulty validators or post-functions, to lead to errors encountered by REST API clients.
4. Issue JSON
When encountering an error related to a specific Jira issue (or a group of issues), having access to the issue data and its history is crucial for Support.
To gather this information, please open the following URLs in your browser (be sure to replace JIRA-URL and NOT_OK_ISSUE-99999 with the appropriate values):
https://JIRA-URL/rest/api/latest/issue/NOT_OK_ISSUE-99999?expand=changelog,names
If there's a Jira issue that's working as expected, it can also be beneficial for Support to compare it with the NOT_OK_ISSUE. You can access this data using the link below:
https://JIRA-URL/rest/api/latest/issue/OK_ISSUE-99999?expand=changelog,names
Once you have retrieved the information, save the contents as NOT_OK_ISSUE-99999.json and OK_ISSUE-99999.json, and then upload these files to the support request.
Jira: Not sending e-mails or not creating tickets from e-mails (or slow e-mail processing)
It is not uncommon for Jira to experience performance issues, such as delays in sending or receiving emails. The underlying causes can vary widely, ranging from internal bottlenecks within Jira to network latency or issues related to mailboxes.
1. Screenshots and types of emails
Jira Software and Jira Service Management use different mail handlers for both incoming and outgoing emails. Therefore, it is important to inform Support about the specific types of emails that are affected.
Please provide screenshots of the relevant cases:
Emails that have ceased to be sent (including one that was successfully sent shortly before the issue occurred).
An example ticket that was no longer created through incoming email (including one that was successfully created shortly before the issue arose).
Additionally, include a screenshot of the mail configuration page:
It is crucial to determine whether the batching notification setting is enabled or disabled.
2. Enabling DEBUG logs
Before you proceed with creating a support zip or gathering logs, it’s important to first enable mail logging and DEBUG as outlined in this helpful article:
Once you’ve done that, please allow Jira to run for a few minutes. During this time, try to perform some actions that would typically trigger the email features in Jira, whether that’s sending or fetching emails. When you reach out to Support, share the specific tests you conducted, such as which issue you created or updated. This information will assist us in narrowing down the scope in the logs more efficiently.
3. Support zips
After enabling mail logs and DEBUG mode for a few minutes, and performing actions that may activate the (faulty or slow) e-mail functionalities, you can generate a support zip file. For this, select the parameters: 3 days, 100 MB file size limit, and include all files.
You may want to disable the DEBUG mode after you're done testing (perhaps by adjusting it to WARN), which will help prevent the application logs from rolling off too quickly. However, you can keep the e-mail logs enabled for ongoing monitoring. It's also important to inform the Support team about your intention to disable DEBUG logs, as they can offer additional assistance if required.
Jira: Replication issues or different data on different nodes
If Jira indicates that there are Index or Cache replication failures, or if you notice discrepancies in the data based on the node to which you are connected, it is advisable to gather the following information for further analysis.
1. Index summary from each node
With the introduction of Document Based Replication (DBR) in Jira 8.12, the relevance of this index summary endpoint has diminished. However, it still holds value in certain situations.
If you can connect to each node, please visit this URL on each of them and copy the output to the support request:
https://node-specific-url/rest/api/2/index/summary
2. Generating thread dumps from each node
Index replication issues frequently arise when replication threads become stuck on certain nodes. To identify these bottlenecks, performing a thread dump on all affected nodes is highly beneficial:
Ensure that you compress the files and name them according to each respective node. Unfortunately, the files do not contain any data that can assist support in correlating them to their originating nodes.
3. Support zips
Lastly, capture a support zip from all nodes and upload them to the support request. This will be incredibly helpful as it contains the relevant logs and configuration data that Support needs to effectively correlate with the thread dump data.
Bitbucket: Bitbucket process unexpectedly terminated
It is possible that the Bitbucket process itself was unexpectedly terminated without any shutdown signal. This could be indicative of the OS (Linux) terminating the process. To check whether this is the case, first determine whether the process is running:
ps -ef | grep -i java
If it is not, in addition to support zips, please provide OS level logs:
- Please provide
/var/log/syslog
or/var/log/messages
- Check for any lines mentioning the OOM-killer from a terminal on the affected node(s)
dmesg -T | grep -C 5 -i “killed process”
Related content
- No related content found