Skip to content
This repository has been archived by the owner on Dec 13, 2023. It is now read-only.

Latest commit

 

History

History
82 lines (59 loc) · 2.72 KB

README.md

File metadata and controls

82 lines (59 loc) · 2.72 KB

Persistence

Persistence modules allow you to run Conductor with different backends for storing metadata and workflow executions. Conductor core has support for Redis and Cassandra, while this module allows additional MySQL and Postgres as options.

Note: Both MySQL and Postgres persistence also implements queue implementations for Conductor. So these modules support the following:

  1. Metadata store
  2. Execution Store
  3. Queue DAO
  4. Concurrency Limits

Published Artifacts

Group: com.netflix.conductor

Published Artifact Description
conductor-mysql-persistence MySQL based Persistence, Concurrency Limiter and Queues
conductor-postgres-persistence Postgres based Persistence, Concurrency Limiter and Queues

Modules

MySQL

Configuration

conductor.db.type=mysql

#Cache expiry for the task definitions in seconds
conductor.mysql.taskDefCacheRefreshInterval=60

#Use spring datasource properties to configure MySQL connection
spring.datasource.url=
spring.datasource.username=
spring.datasource.password=
spring.datasource.hikari.maximum-pool-size=
spring.datasource.hikari.auto-commit=

Postgres

Configuration

(Default values shown below)

conductor.db.type=postgres

#Use spring datasource properties to configure Postgres connection
spring.datasource.url=
spring.datasource.username=
spring.datasource.password=
spring.datasource.hikari.maximum-pool-size=
spring.datasource.hikari.auto-commit=

Additionally, the postgres module includes the ability to index your workflow and task executions and to store task execution logs in Postgres without requiring ElasticSearch.

This can be enabled by setting the following in your application properties file:

conductor.indexing.type=postgres
conductor.indexing.enabled=true
# The following is to force Elastic Search IndexDAO not to run. If it just missing it will still try to start v6
conductor.elasticsearch.version=postgres

It supports full querying of logs through the UI, and exposes the Postgres full text search in two ways. If you search for a chunk of JSON:

{"workflowType":"my_workflow", "version": 3}

It will use an index to search for documents matching the values in the JSON. In this example, all JSON docs with a workflowType attribute set to my_workflow and a version attribute set to 3.

You can also use a full text search on the whole unstructured JSON document. This uses the Postgres tsquery syntax for constructing searches. For example:

my-correlation-id & my-workflow

Will search for any document containing both my-correlation-id and my-workflow.