Elasticsearch exporter
Please refer to supported environments to find out which versions of Elasticsearch are supported in a Camunda 8 Self-Managed setup.
The Zeebe Elasticsearch exporter acts as a bridge between Zeebe and Elasticsearch by exporting records written to Zeebe streams as documents into several indices.
Concept
The exporter operates on the idea that it should perform as little as possible on the Zeebe side of things. In other words, you can think of the indexes into which the records are exported as a staging data warehouse. Any enrichment or transformation on the exported data should be performed by your own ETL jobs.
When configured to do so, the exporter will automatically create an index per record value type (see the value type in the Zeebe protocol). Each of these indexes has a corresponding pre-defined mapping to facilitate data ingestion for your own ETL jobs. You can find those as templates in the resources folder of the exporter's source code.
The indexes are created as required, and will not be created twice if they already exist. However, once disabled, they will not be deleted (that is up to the administrator.) Similarly, data is never deleted by the exporter, and must be deleted by the administrator when it is safe to do so. A retention policy can be configured to automatically delete data after a certain number of days.
Configuration
As the exporter is packaged with Zeebe, it is not necessary to specify a jarPath.
The exporter can be enabled by configuring it with the classpath in the broker settings.
For example:
exporters:
  elasticsearch:
    className: io.camunda.zeebe.exporter.ElasticsearchExporter
    args:
    # Refer to the table below for the available args options
The exporter can be configured by providing args. The table below explains all the different
options, and the default values for these options:
| Option | Description | Default | 
|---|---|---|
| url | Valid URLs as comma-separated string | http://localhost:9200 | 
| requestTimeoutMs | Request timeout (in ms) for the Elasticsearch. client | 30000 | 
| index | Refer to Index for the index configuration options. | |
| bulk | Refer to Bulk for the bulk configuration options. | |
| retention | Refer to Retention for the retention configuration options | |
| authentication | Refer to Authentication for the authentication configuration options. | 
- Index
- Bulk
- Retention
- Authentication
In most cases, you will not be interested in exporting every single record produced by a Zeebe cluster, but rather only a subset of them. This can also be configured to limit the kinds of records being exported (e.g. only events, no commands), and the value type of these records (e.g. only job and process values).
| Option | Description | Default | 
|---|---|---|
| prefix | This prefix will be appended to every index created by the exporter; must not contain _(underscore). | zeebe-record | 
| createTemplate | If truemissing indexes will be created automatically. | true | 
| indexSuffixDatePattern | This suffix will be appended to every index created by the exporter; The pattern is based on the Java DateTimeFormater and supports the same syntax. This is useful when indexes should be created in a different interval, like hourly instead of daily. | "yyyy-MM-dd'" | 
| numberOfShards | The number of shards used for each new record index created. | 3 | 
| numberOfReplicas | The number of shard replicas used for each new record index created. | 0 | 
| templatePriority | The priority used for the index templates created by the exporter. This is only available for 8.7.11 and later versions | 20 | 
| command | If truecommand records will be exported | false | 
| event | If trueevent records will be exported | true | 
| rejection | If truerejection records will be exported | false | 
| checkpoint | If truerecords related to checkpoints will be exported | false | 
| commandDistribution | If truerecords related to command distributions will be exported | true | 
| decision | If truerecords related to decisions will be exported | true | 
| decisionEvaluation | If truerecords related to decision evaluations will be exported | true | 
| decisionRequirements | If truerecords related to decisionRequirements will be exported | true | 
| deployment | If truerecords related to deployments will be exported | true | 
| deploymentDistribution | If truerecords related to deployment distributions will be exported | true | 
| error | If truerecords related to errors will be exported | true | 
| escalation | If truerecords related to escalations will be exported | true | 
| form | If truerecords related to forms will be exported | true | 
| incident | If truerecords related to incidents will be exported | true | 
| job | If truerecords related to jobs will be exported | true | 
| jobBatch | If truerecords related to job batches will be exported | false | 
| message | If truerecords related to messages will be exported | true | 
| messageBatch | If truerecords related to message batches will be exported | false | 
| messageSubscription | If truerecords related to message subscriptions will be exported | true | 
| messageStartEventSubscription | If truerecords related to message start event subscriptions will be exported | true | 
| process | If truerecords related to processes will be exported | true | 
| processEvent | If truerecords related to process events will be exported | false | 
| processInstance | If truerecords related to process instances will be exported | true | 
| processInstanceBatch | If truerecords related to process instances batches will be exported | false | 
| processInstanceCreation | If truerecords related to process instance creations will be exported | true | 
| processInstanceMigration | If truerecords related to process instance migrations will be exported | true | 
| processInstanceModification | If truerecords related to process instance modifications will be exported | true | 
| processMessageSubscription | If truerecords related to process message subscriptions will be exported | true | 
| resourceDeletion | If truerecords related to resource deletions will be exported | true | 
| signal | If truerecords related to signals will be exported | true | 
| signalSubscription | If truerecords related to signal subscriptions will be exported | true | 
| timer | If truerecords related to timers will be exported | true | 
| userTask | If truerecords related to user tasks will be exported | true | 
| variable | If truerecords related to variables will be exported | true | 
| variableDocument | If truerecords related to variable documents will be exported | true | 
To avoid too many expensive requests to the Elasticsearch cluster, the exporter performs batch updates by default. The size of the batch, along with how often it should be flushed (regardless of size) can be controlled by configuration.
| Option | Description | Default | 
|---|---|---|
| delay | Delay, in seconds, before force flush of the current batch. This ensures that even when we have low traffic of records, we still export every once in a while. | 5 | 
| size | The amount of records a batch should have before we flush the batch | 1000 | 
| memoryLimit | The size of the batch, in bytes, before we flush the batch | 10485760(10 MB) | 
With the default configuration, the exporter will aggregate records and flush them to Elasticsearch:
- When it has aggregated 1000 records.
- When the batch memory size exceeds 10 MB.
- Five seconds have elapsed since the last flush (regardless of how many records were aggregated).
A retention policy can be set up to delete old data.
When enabled, this creates an Index Lifecycle Management (ILM) Policy that deletes the data after the specified minimumAge.
All index templates created by this exporter apply the created ILM Policy.
| Option | Description | Default | 
|---|---|---|
| enabled | If truethe ILM Policy is created and applied to the index templates | false | 
| minimumAge | Specifies how old the data must be, before the data is deleted as a duration | 30d | 
| policyName | The name of the created and applied ILM policy | zeebe-record-retention-policy | 
The duration can be specified in days d, hours h, minutes m, seconds s, milliseconds ms, and/or nanoseconds nanos.
Providing these authentication options will enable Basic Authentication on the exporter.
| Option | Description | Default | 
|---|---|---|
| username | Username used to authenticate | N/A | 
| password | Password used to authenticate | N/A | 
Example
Here is an example configuration of the exporter:
---
exporters:
  elasticsearch:
    # Elasticsearch Exporter ----------
    # An example configuration for the elasticsearch exporter:
    #
    # These setting can also be overridden using the environment variables "ZEEBE_BROKER_EXPORTERS_ELASTICSEARCH_..."
    #
    className: io.camunda.zeebe.exporter.ElasticsearchExporter
    args:
      # A comma separated list of URLs pointing to the Elasticsearch instances you wish to export to.
      # For example, if you want to connect to multiple nodes for redundancy:
      # url: http://localhost:9200,http://localhost:9201
      url: http://localhost:9200
      bulk:
        delay: 5
        size: 1000
        memoryLimit: 10485760
      retention:
        enabled: true
        minimumAge: 30d
        policyName: zeebe-records-retention-policy
      authentication:
        username: elastic
        password: changeme
      index:
        prefix: zeebe-record
        createTemplate: true
        indexSuffixDatePattern: "yyyy-MM-dd"
        command: false
        event: true
        rejection: false
        commandDistribution: true
        decisionRequirements: true
        decision: true
        decisionEvaluation: true
        deployment: true
        deploymentDistribution: true
        error: true
        escalation: true
        form: true
        incident: true
        job: true
        jobBatch: false
        message: true
        messageStartSubscription: true
        messageSubscription: true
        process: true
        processEvent: false
        processInstance: true
        processInstanceCreation: true
        processInstanceMigration: true
        processInstanceModification: true
        processMessageSubscription: true
        resourceDeletion: true
        signal: true
        signalSubscription: true
        timer: true
        userTask: true
        variable: true
        variableDocument: true
Self-signed certificates
The Zeebe Elasticsearch exporter does not currently support connecting to Elasticsearch using self-signed certificates. If you must use self-signed certificates, it is possible to build your own trust store and have the application use it.
In this case, it is recommended to create a new custom trust store based on the default one. This way, it will also be able to verify certificates signed using trusted root certificate authorities.
- 
First, create a new custom trust store which contains the same data as the default one, using PKCS12 format. To do so, find the location of the default cacertstrust store:- On Linux systems, find it at $JAVA_HOME/lib/security/cacerts.
- For macOS, find it under $(/usr/libexec/java_home)/jre/lib/security/cacerts.
 Once you have the right location, e.g. $JAVA_HOME/lib/security/cacerts, run the following to create a new trust store:keytool -importkeystore -srckeystore $JAVA_HOME/lib/security/cacerts -destkeystore zeebeTrustStore.jks -srcstoretype PKCS12 -deststoretype JKSSet any password, so long as it's at least 6 characters. 
- On Linux systems, find it at 
- 
Add your custom certificate to to the new trust store. For example, if your custom certificate is located at /tmp/myCustomCertificate.pem:keytool -import -alias MyCustomCertificate -keystore zeebeTrustStore.jks -file /tmp/myCustomCertificate.pemnoteReplace the -fileparameter with the actual path to your certificate, and make sure to replace the-aliasparameter with something descriptive, likeWebServerCertificate.When prompted to trust the certificate, make sure to answer yes. 
- 
Update the application to use this trust store. First, make sure the file is readable by the application. For example, on Unix systems, run: chmod a+r zeebeTrustStore.jksThen, specify the following properties when running the application: - javax.net.ssl.trustStore: must be set to the path of your custom trust store.
- javax.net.ssl.trustStorePassword: set to your trust store password.
 The following example uses a trust store location of /tmp/zeebeTrustStore.jks, and a password ofchangeme. When using the official distribution (whether Docker image or the bundled shell scripts), these propertiescan be provided using the following environment variable:JAVA_OPTS="-Djavax.net.ssl.trustStore=/tmp/zeebeTrustStore.jks -Djavax.net.ssl.trustStorePassword=changeme ${JAVA_OPTS}"
If you're using containers, you will need to mount the trust store to the container such that it can be found by the java process. This will depend on
your deployment method (e.g. Helm chart, Docker Compose). The simplest way is to build a custom image which already contains your trust store, and specifies
the environment variable.