README
ΒΆ
Process Compose
Process compose is a lightweight utility for building custom workflows and execution sequences. It is optimized for:
- Parallelizing processes execution
- Defining execution dependencies and order
- Defining recovery policies (restart
on-failure,always,no) - Declaring processes arguments
- Declaring processes environment variables
It is heavily inspired by docker-compose, but without the need for containers. The configuration syntax tries to follow the docker-compose specifications, with a few minor additions and lots of subtractions.
Installation
- Download one of the releases
Documentation
- See examples of workflows for best practices
- See below
List of Features and Planned Features
β Mostly implemented
β Implementation not started (Your feedback and β will motivate further development π)
β Launcher
β Parallel
process1:
command: "sleep 3"
process2:
command: "sleep 3"
β Serial
process1:
command: "sleep 3"
depends_on:
process2:
condition: process_completed_successfully # or "process_completed" if you don't care about errors
process2:
command: "sleep 3"
depends_on:
process3:
condition: process_completed_successfully # or "process_completed" if you don't care about errors
β Instance Number
β Define process dependencies
process2:
depends_on:
process2:
condition: process_completed_successfully # or "process_started" (default)
process3:
condition: process_completed_successfully
β Output Handling
β Show process name
β Different colors per process
β StdErr is printed in Red
β Silence specific processes
β Logger
β Per Process Log Collection
process2:
log_location: ./pc.process2.log #if undefined or empty no logs will be saved
β Capture StdOut output
β Capture StdErr output
β Merge into a single file
processes:
process2:
command: "chmod 666 /path/to/file"
environment:
- 'ABC=42'
log_location: ./pc.global.log #if undefined or empty no logs will be saved (if also not defined per process)
β Silence specific processes
β Process compose console log level
log_level: info # other options: "trace", "debug", "info", "warn", "error", "fatal", "panic"
processes:
process2:
command: "chmod 666 /path/to/file"
This setting controls the process-compose log level. The processes log level should be defined inside the process. It is recommended to support its definition with an environment variable that can be defined in process-compose.yaml
β Health Checks
β Is Alive
β Is Ready
β Auto Restart if not healthy
β Auto Restart on exit
process2:
availability:
restart: on-failure # other options: "always", "no" (default)
backoff_seconds: 2 # default: 1
max_restarts: 5 # default: 0 (unlimited)
β Environment Variables
β Per Process
process2:
environment:
- 'I_AM_LOCAL_EV=42'
β Global
processes:
process2:
command: "chmod 666 /path/to/file"
environment:
- 'I_AM_LOCAL_EV=42'
environment:
- 'I_AM_GLOBAL_EV=42'
β System Variables
β Process replica number
β Monitoring
β REST API
β Configuration
β Support .env file
β Override ${var} and $var from environment variables or .env values
β Merge 2 or more configuration files with override values
β Specify which configuration files to use
process-compose -f "path/to/process-compose-file.yaml"
β Auto discover configuration files
The following discovery order is used: compose.yml, compose.yaml, process-compose.yml, process-compose.yaml. If multiple files are present the first one will be used.
β Multi-platform
β Linux
β Windows
β macOS
Click to show internal directories.
Click to hide internal directories.