Home

Awesome

Conductor

Announcement

Effective December 13, 2023, Netflix will discontinue maintenance of Conductor OSS on GitHub. This strategic decision, while difficult, is essential for realigning our resources to better serve our business objectives with our internal Conductor fork.

We are deeply grateful for your support and contributions over the years. While Netflix will no longer be maintaining this repo, members of the Conductor community have been active in promoting alternative forks of this project, we’ll leave the code as is and trust that the health of the community will remain strong and continue to develop moving forward.

Conductor

NetflixOSS Lifecycle Github release License

GitHub stars GitHub forks

Conductor is a platform created by Netflix to orchestrate workflows that span across microservices.

Releases

The final release is Github release

Workflow Creation in Code

Conductor supports creating workflows using JSON and Code.
SDK support for creating workflows using code is available in multiple languages and can be found at https://github.com/conductor-sdk

Community Contributions

The modules contributed by the community are housed at conductor-community. Compatible versions of the community modules are released simultaneously with releases of the main modules.

Discussion Forum: Please use the forum for questions and discussing ideas and join the community.

List of Conductor community projects: Backup tool, Cron like workflow starter, Docker containers and more.

Getting Started - Building & Running Conductor

Using Docker:

The easiest way to get started is with Docker containers. Please follow the instructions here.

From Source:

Conductor Server is a Spring Boot project and follows all applicable conventions. See instructions here.

Published Artifacts

Binaries are available from the Maven Central Repository.

ArtifactDescription
conductor-commonCommon models used by various conductor modules
conductor-coreCore Conductor module
conductor-redis-persistencePersistence and queue using Redis/Dynomite
conductor-cassandra-persistencePersistence using Cassandra
conductor-es6-persistenceIndexing using Elasticsearch 6.X
conductor-restSpring MVC resources for the core services
conductor-uinode.js based UI for Conductor
conductor-clientJava client for Conductor that includes helpers for running worker tasks
conductor-client-springClient starter kit for Spring
conductor-java-sdkSDK for writing workflows in code
conductor-serverSpring Boot Web Application
conductor-redis-lockWorkflow execution lock implementation using Redis
conductor-awss3-storageExternal payload storage implementation using AWS S3
conductor-awssqs-event-queueEvent queue implementation using AWS SQS
conductor-http-taskWorkflow system task implementation to send make requests
conductor-json-jq-taskWorkflow system task implementation to evaluate JSON using jq
conductor-grpcProtobuf models used by the server and client
conductor-grpc-clientgRPC client to interact with the gRPC server
conductor-grpc-servergRPC server Application
conductor-test-harnessIntegration and regression tests

Database Requirements

Other Requirements

Get Support

There are several ways to get in touch with us:

Contributions

Whether it is a small documentation correction, bug fix or a new feature, contributions are highly appreciated. We just ask you to follow standard OSS guidelines. The Discussion Forum is a good place to ask questions, discuss new features and explore ideas. Please check with us before spending too much time, only to find out later that someone else is already working on a similar feature.

main branch is the current working branch. Please send your PR's to main branch, making sure that it builds on your local system successfully. Also, please make sure all the conflicts are resolved.

License

Copyright 2022 Netflix, Inc.

Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at

http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.