Architecture
- Engine - handles control and data flow of workflow executions. Computes which
tasks are ready and places them in a queue. Passes the data from task to
task, deals with condition transitions, etc.
- Task Executors - execute task Actions. Pick up tasks from the queue, run
actions, and send results back to the engine.
- API server - exposes REST API to operate and monitor workflow executions.
- Scheduler - stores and executes delayed calls. It is the important Mistral
component since it interacts with engine and executors. It also triggers
workflows on events (e.g., periodic cron event)
- Persistence - stores workflow definitions, current execution states, and
past execution results.