Configuration
Environment Variables
Local (Per Process)
Global
environment:
- "I_AM_GLOBAL_EV=42"
processes:
process2:
command: "chmod 666 /path/to/file"
environment:
- "I_AM_LOCAL_EV=42"
Default environment variables:
PC_PROC_NAME
- Defines the process name as defined in the process-compose.yaml
file.
PC_REPLICA_NUM
- Defines the process replica number. Useful for port collision avoidance for processes with multiple replicas.
.env file
Override ${var} and $var from environment variables or .env valuesprocesses:
downloader:
command: "python3 data_downloader_${VERSION}.py -s 'data.source.B.uri'"
availability:
restart: "always"
backoff_seconds: ${WAIT_SEC}
environment:
- 'OUTPUT_DIR=/path/to/B/data'
By default the .env
file in the current directory is used if exists. It is possible to specify other file(s) to be used instead:
For situations where the you would like to disable the automatic .env
file loading you might want to use the --disable-dotenv
flag.
.pc_env file
.pc_env
file allows you to control Process Compose local, user environment specific settings.
Ideally it should contain Process Compose specific environment variables:
Disable Automatic Expansion
Process Compose provides 2 ways to disable the automatic environment variables expansion:
- Escape the environment variables with
$$
. Example:
Output: I am ready
- Globally disable the automatic expansion with
disable_env_expansion: true
. Example:
Output: I am ready
Note: The default behavior for the following
process-compose.yaml
:Output:
I am
Environment Commands
The env_cmds
feature allows you to dynamically populate environment variables by executing short commands before starting your processes. This is useful when you need environment values that are determined at runtime or need to be fetched from the system.
Configuration
Environment commands are defined in the env_cmds
section of your process-compose.yaml
file. Each entry consists of:
- An environment variable name (key)
- A command to execute (value)
Example Configuration
Usage
To use the environment variables populated by env_cmds
, reference them in your process definitions using $${VAR_NAME}
syntax:
Constraints and Considerations
-
Execution Time: Commands should complete within 2 seconds. Longer-running commands may cause process-compose startup delays or timeouts.
-
Command Output:
- Commands should output a single line of text
- The output will be trimmed of leading/trailing whitespace
-
The output becomes the value of the environment variable
-
Error Handling:
- If a command fails, the environment variable will not be set
- Process-compose will log any command execution errors
Best Practices
- Keep commands simple and fast-executing
- Use commands that produce consistent, predictable output
- Validate command output format before using in production
- Consider caching values that don't need frequent updates
Example Use Cases
-
System Information:
-
Time-based Values:
-
Resource Information:
Variables
Variables in Process Compose rely on Go template engine
Rendered Parameters:
processes.process.command
processes.process.working_dir
processes.process.log_location
processes.process.description
- For
readiness_probe
andliveness_probe
: processes.process.<probe>.exec.command
processes.process.<probe>.http_get.host
processes.process.<probe>.http_get.path
processes.process.<probe>.http_get.scheme
processes.process.<probe>.http_get.port
Local (Per Process)
processes:
watcher:
vars:
LOG_LOCATION: "./watcher.log"
OK: SUCCESS
PRE: 2
POST: 8
command: "sleep {{.PRE}} && echo {{.OK}} && sleep {{.POST}}"
log_location: {{.LOG_LOCATION}}
readiness_probe:
exec:
command: "grep -q {{.OK}} {{.LOG_LOCATION}}"
initial_delay_seconds: 1
period_seconds: 1
timeout_seconds: 1
success_threshold: 1
Notice the
.
(dot) before each.VARIABLE
Global
vars:
VERSION: v1.2.3
FTR_A_ENABLED: true
FTR_B_ENABLED: true
processes:
version:
# Environment and Process Compose variables can complement each other
command: "echo 'version {{or \"${VERSION}\" .VERSION}}'"
feature:
command: "echo '{{if .FTR_A_ENABLED}}Feature A Enabled{{else}}Feature A Disalbed{{end}}'"
not_supported:
command: "echo 'Hi {{if and .FTR_A_ENABLED .FTR_B_ENABLED}}Not Supported{{end}}'"
#output:
version v1.2.3 #if $VERSION environment variable is undefined. The value of $VERSION if it is.
Feature A Enabled
Not Supported
Template Escaping
In a scenario where Go template syntax is part of your command, you will want to escape it:
For example:
processes:
nginx:
command: "docker run -d --rm -p80:80 --name nginx_test nginx"
liveness_probe:
exec:
command: '[ $(docker inspect -f "{{.State.Running}}" nginx_test) = true ]'
Will become:
processes:
nginx:
command: "docker run -d --rm -p80:80 --name nginx_test nginx"
liveness_probe:
exec:
command: '[ $(docker inspect -f {{ "{{.State.Running}}" }} nginx_test) = true ]'
Auto Inserted Variables
Process Compose will insert PC_REPLICA_NUM
variable that will represent the replica number of the process. This will allow to conveniently scale processes using the following example configuration:
processes:
server:
command: "python3 -m http.server 404{{.PC_REPLICA_NUM}}"
is_tty: true
readiness_probe:
http_get:
host: "127.0.0.1"
port: "404{{.PC_REPLICA_NUM}}"
scheme: "http"
Specify which configuration files to use
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.
Merge 2 or more configuration files with override values
process-compose -f "path/to/process-compose-file.yaml" -f "path/to/process-compose-override-file.yaml"
Using multiple process-compose
files lets you customize a process-compose
application for different environments or different workflows.
See the Merging Configuration for more information on merging files.
On the Fly Configuration Edit
Process Compose allows you to edit processes configuration without restarting the entire project. To achieve that, select one of the following options:
Project Edit
Modify your process-compose.yaml
file (or files) and apply the changes by running:
process-compose project update -f process-compose.yaml # add -v for verbose output, add -f for additional files to be merged
This command will:
- If there are changes to existing processes in the updated
process-compose.yaml
file, stop the old instances of these processes and start new instances with the updated config. - If there are only new processes in the updated
process-compose.yaml
file, start the new processes without affecting the others. - If some processes no longer exist in the updated
process-compose.yaml
file, stop only those old processes without touching the others.
Note: If TUI or TUI client is being used, you can trigger the original files reload with the Ctrl+L
shortcut.
Process Edit
To edit a single process:
- Select it in the TUI or in the TUI client.
- Press
CTRL+E
- Apply the changes, save and quit the editor.
- The process will restart with the new configuration, or won't restart if there are no changes.
Notes:
- These changes are not persisted and not applied to your
process-compose.yaml
- In case of parsing errors or unrecognized fields:
- All the changes will be reverted to the last known correct state.
- The editor will open again with a detailed error description at the top of the file.
- Process Compose will use one of:
- Your default editor defined in
$EDITOR
environment variable. If empty: - For non-Windows OSs:
vim
,nano
,vi
in that order. - For Windows OS:
notepad.exe
,notepad++.exe
,code.exe
,gvim.exe
in that order. - Some of the fields are read only.
Backend
For cases where your process compose requires a non default or transferable backend definition, setting an environment variable won't do. For that, you can configure it directly in the process-compose.yaml
file:
version: "0.5"
shell:
shell_command: "python3"
shell_argument: "-m"
processes:
http:
command: "server.py"
Note: please make sure that the
shell.shell_command
value is in your$PATH
Linux
The default backend is bash
. You can define a different backend with a COMPOSE_SHELL
environment variable.
Windows
The default backend is cmd
. You can define a different backend with a COMPOSE_SHELL
environment variable.
process1:
command: "python -c print(str(40+2))"
#note that the same command for bash/zsh would look like: "python -c 'print(str(40+2))'"
Using powershell
backend had some funky behavior (like missing command1 && command2
functionality in older versions). If you need to run powershell scripts, use the following syntax:
macOS
The default backend is bash
. You can define a different backend with a COMPOSE_SHELL
environment variable.
Namespaces
Assigning namespaces to processes allows better grouping and sorting, especially in TUI:
processes:
process1:
command: "tail -f -n100 process-compose-${USER}.log"
working_dir: "/tmp"
namespace: debug # if not defined 'default' namespace is automatically assigned to each process
Note: By default process-compose
will start process from all the configured namespaces. To start a sub set of the configured namespaces (ns1
, ns2
, ns3
):
process-compose -n ns1 -n ns3
# will start only ns1 and ns3. ns2 namespace won't run and won't be visible in the TUI
Misc
Strict Configuration Validation
To avoid minor proces-compose.yaml
configuration errors and typos it is recommended to enable is_strict
flag:
1
:
Pseudo Terminals
Certain processes check if they are running within a terminal, to simulate a TTY mode you can use a is_tty
flag:
STDIN
andWindows
are not supported at this time.
Elevated Processes
Process Compose uses sudo
(on Linux and macOS) and runas
(on Windows) to enable execution of elevated processes in both TUI and headless modes.
processes:
elevated_ls:
description: "run an elevated process"
command: "ls -l /root"
is_elevated: true
shutdown:
signal: 9
Enter
key.
* To exit the password prompt, press the ESC
key at any time.
* To re-enter password mode, select the process again.
* The entered password will be applied to all elevated processes in pending status.
Multiline Command Support
Process Compose respects all the multiline YAML
specification variations.
Examples:
processes:
block_folded:
command: >
echo 1
&& echo 2
echo 3
block_literal:
command: |
echo 4
echo 5
depends_on:
block_folded:
condition: process_completed
flow_single:
command: 'echo 6
&& echo 7
echo 8'
depends_on:
block_literal:
condition: process_completed
flow_double:
command: "echo 9
&& echo 10
echo 11"
depends_on:
flow_single:
condition: process_completed
flow_plain:
command: echo 12
&& echo 13
echo 14
depends_on:
flow_double:
condition: process_completed
The extra blank lines (
\n
) in the command string are to introduce a newline to the command.