Monolithic docker-compose files filtered with profiles
Those of us who use docker-compose to manage our fleets of containers generally fall into two camps. Camp A prefers one monolithic docker-compose file per host using docker-compose <command> <service>
to interact with each service. Camp B split up their configuration into multiple files with some kind of logical grouping which makes sense to them.
This post will provide an overview of using profiles with docker-compose to address multiple services within a monolithic file. This aims to provide all the advantages of Camp B's approach without the faff and hassle of changing directories or managing multiple compose files.
Example A
Take the following compose file:
version: "3.3"
services:
nginx1:
image: nginx
container_name: nginx1
profiles:
- prod
- test
nginx2:
image: nginx
container_name: nginx2
profiles:
- prod
nginx3:
image: nginx
container_name: nginx3
profiles:
- test
Using the profiles it's possible to put a single service into more than profile at once giving much more flexibility than multiple files as Camp B would typically do.
alex@slartibartfast tmp % docker-compose --profile test up -d
[+] Running 2/2
⠿ Container nginx3 Started 0.5s
⠿ Container nginx1 Started
As you can see above nginx1
and nginx3
were both started because they are members of the profile test
. Profiles support all operations that you'd expect via compose and the full documentation can be found over in Docker's documentation.
Note that if you include a profile a simple docker-compose up -d
will fail:
alex@slartibartfast tmp % docker-compose up -d
no service selected
These profiles aren't perfect and certainly have nuances you will need to become familiar with but they are quite promisingly useful.
Conclusion
A relatively short post this but after a discussion on the Self-Hosted discord server earlier the topic of monolith vs multiple smaller files came up. It occurred to me there must be a way to filter containers and this is what I found.
Hope you found this useful. Let me know if you use this in the real world!