-
-
Notifications
You must be signed in to change notification settings - Fork 54
Multiple Compose Files
Using multiple process-compose
files lets you to customize a process-compose
application for different environments or different workflows.
By default, process-compose
reads two files, a process-compose.yml
and an optional process-compose.override.yml
file. By convention, the process-compose.yml
contains your base configuration. The override file, as its name implies, can contain configuration overrides for existing processes or entirely new processes.
If a process is defined in both files, process-compose
merges the configurations using the rules described in Adding and overriding configuration.
To use multiple override files, or an override file with a different name, you can use the -f
option to specify the list of files. process-compose
merges files in the order they’re specified on the command line.
When you use multiple configuration files, you must make sure all paths in the files are relative to the base process-compose
file (the first process-compose
file specified with -f
). This is required because override files need not be valid process-compose
files. Override files can contain small fragments of configuration. Tracking which fragment of a process is relative to which path is difficult and confusing, so to keep paths easier to understand, all paths must be defined relative to the base file.
A common use case for multiple files is changing a development process-compose
app for a production-like environment (which may be production, staging or CI). To support these differences, you can split your process-compose
configuration into a few different files:
Start with a base file that defines the canonical configuration for the processes.
process-compose.yml
processes:
web:
command: "npm start"
depends_on:
db:
condition: process_started
cache:
condition: process_started
db:
command: "pg_ctl start -l logfile"
cache:
command: "systemctl start redis"
In this example the development configuration adds debug flags.
process-compose.override.yml
processes:
web:
environment:
- "DEBUG=true"
db:
command: "pg_ctl start -l logfile -d"
When you run process-compose
it reads the overrides automatically.
Now, it would be nice to use this process-compose
app in a production environment. So, create another override file (which might be stored in a different git repo or managed by a different team).
process-compose.prod.yml
processes:
web:
environment:
- "PRODUCTION=true"
cache:
environment:
- "TTL=500"
To deploy with this production process-compose
file you can run
$ process-compose -f process-compose.yml -f process-compose.prod.yml
This deploys all three processes using the configuration in process-compose.yml
and process-compose.prod.yml
(but not the dev configuration in process-compose.override.yml
).
process-compose
copies configurations from the original process over to the local one. If a configuration option is defined in both the original process and the local process, the local value replaces or extends the original value.
For single-value options like command
, working_dir
or disabled
, the new value replaces the old value.
original process:
processes:
myprocess:
# ...
command: python app.py
local process:
processes:
myprocess:
# ...
command: python otherapp.py
result:
processes:
myprocess:
# ...
command: python otherapp.py
For the multi-value options environment
, depends_on
, process-compose
merges entries together with locally-defined values taking precedence:
original process:
processes:
myprocess:
# ...
environment:
- "A=3"
local process:
processes:
myprocess:
# ...
environment:
- "A=4"
- "B=5"
result:
processes:
myprocess:
# ...
environment:
- "A=4"
- "B=5"