Data pipeline
Requirements
To trigger data exports through the REST API, you’ll need:
- A valid Jira Data Center license
- Jira system administrator permissions. See Security overview for more information about supported API authentication methods.
Considerations
There are a number of security and performance impacts you’ll need to consider before getting started.
Security
If you need to filter out data based on security and confidentiality, this must be done after the data is exported.
Exported files are saved in your shared home directory, so you’ll also want to check this is secured appropriately.
Export performance
To minimize the risk of performance problems, we strongly recommend that you:
- Perform the data export during hours of low activity, or on a node with no activity.
- Limit the amount of data exported through the
fromDate
parameter, as a date further in the past will export more data, resulting in a longer data export.
Export scope | Approximate export duration | |
---|---|---|
1 million issues | 7 million issues | |
Jira Software | ||
| 15 minutes | 2 hours |
| 1 hour | 9 hours |
| 5 hours | 22 hours |
Jira Software and Jira Service Management | ||
| 30 minutes to 2 hours | 3 to 6 hours |
Test performance VS production
The performance data presented here is based on our own internal regression testing. The actual duration and impact of a data export on your own environment will likely differ depending on:
- your infrastructure, configuration, and load
- applications installed (Jira Software and Jira Service Management)
- amount of custom field and issue history data to be exported.
We used Jira Performance Tests to test a data export's performance on a Jira Data Center environment on AWS. This environment had one c5.9xlarge Jira node and one PostgreSQL database. To test user load, we used 24 virtual users across 2 virtual user nodes.
We intentionally export data quite slowly to keep any performance degradation on the node running the export under a 5% threshold. You may want to use your load balancer to redirect traffic away from the node performing the export.
Perform an export
If your application is configured to use a context path, such as /jira, remember to include this in the <base-url>
in the examples below.
To export the current state data, make a POST
request to <base-url>/rest/datapipeline/latest/export
.
Use the fromDate
parameter to limit the data exported to just entities created or updated after the fromDate
value.
This parameter only accepts date values set in ISO 8601 format (yyyy-MM-ddTHH:mmTZD). For example:
- 2020-12-30T23:01Z
- 2020-12-30T22:01+01:00
(you'll need to use URL encoding in your request, for example2020-12-30T22%3A03%2B01%3A00
)
If you trigger an export without the fromDate parameter, all data from the last 365 days will be exported.
Here is an example request, using cURL and a personal access token for authentication:
curl -H "Authorization:Bearer ABCD1234" -H "X-Atlassian-Token: no-check"
-X POST https://myexamplesite.com/rest/datapipeline/latest/
export?fromDate=2020-10-22T01:30:11Z
The "X-Atlassian-Token: no-check"
header is only required for Confluence. You can omit this for Jira.
The POST
request returns the following responses.
Check the status of an export
You can check the status of an export and view when your last export ran from within your application’s admin console. To view data export status:
- In the upper-right corner of the screen, select Administration > System.
- Select Data pipeline
- Not started - no export is currently running
- Started - the export is currently running
- Completed - the export has completed
- Cancellation requested - a cancellation request has been sent
- Cancelled - the export was cancelled
- Failed - the export failed.
For help resolving failed or cancelled exports, see Data pipeline troubleshooting.
GET
request to <base-url>/rest/datapipeline/latest/export
.The GET
request returns a 200
code, but the responses will differ depending on the stage the export is in.
The GET
request returns the following responses.
Cancel an export
DELETE
request to <base-url>/rest/datapipeline/latest/export
.The DELETE
request returns the following responses.
Automatic data export cancellations
CANCELLED
.However, if the JVM is not notified after a crash or hardware-level failure occurs, the export process may get locked. This means you'll need to manually mark the export as CANCELLED by making a DELETE
request. This releases the process lock, allowing you to perform another data export.
Configuring the data export
You can configure the format of the export data through the following system properties.
Default value | Description |
---|---|
plugin.data.pipeline.embedded.line.break.preserve | |
false | Specifies whether embedded line breaks should be preserved in the output files. Line breaks can be problematic for some tools such as Hadoop. This property is set to |
plugin.data.pipeline.embedded.line.break.escape.char | |
\\n | Escaping character for embedded line breaks. By default, we'll print |
You can further configure your export to exclude certain types of data using feature flags. See How to manage dark features in Jira to learn how to use feature flags.
Default value | Description |
---|---|
data.pipeline.feature.jira.all.exportable.custom.fields.enabled | |
Enabled | Specifies whether custom field data should be included in the export. Exporting custom field data may increase your export duration, depending on the amount of custom field data you have. Change the |
data.pipeline.feature.jira.issue.history.export.enabled | |
Enabled | Specifies whether historical issue data should be included in the export. Exporting historical data will significantly increase your export duration. Change the |
Output files
Each time you perform a data export, we assign a numerical job ID to the task (starting with 1 for your first ever data export). This job ID is used in the file name, and location of the files containing your exported data.
Location of exported files
Exported data is saved as separate CSV files. The files are saved to the following directory:
<shared-home>/data-pipeline/export/<job-id>
if you run Jira in a cluster<local-home>/data-pipeline/export/<job-id>
you are using non-clustered Jira
Within the <job-id>
directory you will see the following files:
issues_job<job_id>_<timestamp>.csv
(for issues)
(for Jira Software and Jira Service Management fields)issue_fields_job<job_id>_<timestamp>.csv
issue_history_job<job_id>_<timestamp>.csv
(for historical issue activity)sla_cycles_job<job_id>_<timestamp>.csv
(for SLA cycle information, if Jira Service Management is installed)
To load and transform the data in this export, you'll need to understand its schema. See Data pipeline export schema.
Set a custom export path
To change the root export path, make a PUT
request to <base-url>/rest/datapipeline/1.0/config/export-path
.
In the body of the request pass the absolute path to your preferred directory, for example:
{
"path": "/tmp/new/path"
}
The PUT
request returns the following response:
To check the export path, make a GET
request to <base-url>/rest/datapipeline/1.0/config/export-path
.
The GET
request returns the following responses.
Revert to the default export path
To revert to the default path, make a DELETE
request to <base-url>/rest/datapipeline/1.0/config/export-path
.
Sample Spark and Hadoop import configurations
If you have an existing Spark or Hadoop instance, use the following references to configure how to import your data for further transformation: