Docker Compose
Komodo can deploy docker compose projects through the Stack
resource.
Define the compose file/s
Komodo supports 3 ways of defining the compose files:
- Write them in the UI, and Komodo will write them to your host at deploy-time.
- Store them in a git repo, and have Komodo clone it on the host to deploy.
- Store the files anywhere on the host, and Komodo will just run the compose commands on the existing files.
The recommended way to deploy Stacks is using compose files located in a git repo.
If you manage your compose files in git repos:
- All your files, across all servers, are available locally to edit in your favorite text editor.
- All of your changes are tracked, and can be reverted.
- You can use the git webhooks to do other automations when you change the compose file contents. Redeploying will be as easy as just
git push
.
Many Komodo resources need access to git repos. There is an in-built token management system (managed in UI or in config file) to give resources access to credentials. All resources which depend on git repos are able to use these credentials to access private repos.
Importing Existing Compose projects
First create the Stack in Komodo, and ensure it has access to the compose files using one of the three methods above. Make sure to attach the server you wish to deploy on.
In order for Komodo to pick up a running project, it has to know the compose "project name".
You can find the project name by running docker compose ls
on the host.
By default, Komodo will assume the Stack name is the compose project name. If this is different than the project name on the host, you can configure a custom "Project Name" in the config.
Pass Environment Variables
Komodo is able to pass custom environment variables to the docker compose process. This works by:
- Write the variables to a ".env" file on the host at deploy-time.
- Pass the file to docker compose using the
--env-file
flag.
Just like all other resources with Environments (Deployments, Repos, Builds), Stack Environments support Variable and Secret interpolation. Define global variables in the UI and share the values across environments.
Using bind mounts
Repo-based stacks must delete the stack folder before it is able to reclone for the latest repo contents. Because of this, users should avoid using relative file paths that are placed inside the repo directory. Or better yet, make things simple and use absolute file paths or docker volumes instead.