Faraday Conductor: Orchestrates docker-compose for large, multi-pod apps

Latest version License Build Status

This is a work in progress using the docker_compose library. It's a reimplementation of our internal, ad hoc tools using the new docker-compose.yml version 2 format and Rust.

API Documentation

What's this for?

If you answer to one or more of these questions is "yes", then conductor is probably for you. It provides development and deployment tools for complex docker-compose apps, following a [convention over configuration][] philosophy.

Installation

To install, we recommend using rustup and cargo:

sh curl https://sh.rustup.rs -sSf | sh cargo install conductor

Usage

To see how to use conductor, run conductor --help (which may be newer than this README during development):

``` conductor: Manage large, multi-pod docker-compose apps

Usage: conductor [options] conductor [options] new conductor [options] pull conductor [options] up conductor [options] stop conductor [options] exec [exec options] [--] [..] conductor [options] shell [exec options] conductor [options] test conductor [options] repo list conductor [options] repo clone conductor (--help | --version)

Commands: pull Pull Docker images used by project up Run project stop Stop all containers associated with project exec Run a command inside a container shell Run an interactive shell inside a running container test Run the tests associated with a service, if any repo list List all git repository aliases and URLs repo clone Clone a git repository using its short alias and mount it into the containers that use it

Arguments: Short alias for a repo (see repo list) The name of a pod specified in pods/ The name of a service in a pod

Exec options: -d Run command detached in background --privileged Run a command with elevated privileges --user User as which to run a command -T Do not allocate a TTY when running a command

General options: -h, --help Show this message --version Show the version of conductor --override= Use overrides from the specified subdirectory of pods/overrides [default: development] --default-tags= A list of tagged image names, one per line, to be used as defaults for images

Run conductor in a directory containing a pods subdirectory. For more information, see https://github.com/faradayio/conductor. ```

What's a pod?

A "pod" is a tightly-linked group of containers that are always deployed together. Kubernetes defines pods as:

A pod (as in a pod of whales or pea pod) is a group of one or more containers (such as Docker containers), the shared storage for those containers, and options about how to run the containers. Pods are always co-located and co-scheduled, and run in a shared context. A pod models an application-specific “logical host” - it contains one or more application containers which are relatively tightly coupled — in a pre-container world, they would have executed on the same physical or virtual machine.

If you're using Amazon's ECS, a pod corresponds to an ECS "task" or "service". If you're using Docker Swarm, a pod corresponds to a single docker-compose.xml file full of services that you always launch as a single unit.

Pods typically talk to other pods using ordinary DNS lookups or service discovery. If a pod accepts outside network connections, it will often do so via a load balancer.

Project format

See examples/hello for a complete example.

hello └── pods ├── common.env ├── frontend.yml └── overrides ├── development │   └── common.env ├── production │   ├── common.env │   └── frontend.yml └── test └── common.env