2015-01-20 16:23:16 +01:00
|
|
|
Docker Compose
|
|
|
|
==============
|
2014-01-11 15:17:00 +01:00
|
|
|
|
2014-10-01 21:50:30 +02:00
|
|
|
[![wercker status](https://app.wercker.com/status/d5dbac3907301c3d5ce735e2d5e95a5b/s/master "wercker status")](https://app.wercker.com/project/bykey/d5dbac3907301c3d5ce735e2d5e95a5b)
|
2013-12-09 13:01:15 +01:00
|
|
|
|
2015-02-25 16:01:40 +01:00
|
|
|
*(Previously known as Fig)*
|
|
|
|
|
2015-02-16 20:21:17 +01:00
|
|
|
Compose is a tool for defining and running complex applications with Docker.
|
|
|
|
With Compose, you define a multi-container application in a single file, then
|
|
|
|
spin your application up in a single command which does everything that needs to
|
|
|
|
be done to get it running.
|
|
|
|
|
|
|
|
Compose is great for development environments, staging servers, and CI. We don't
|
|
|
|
recommend that you use it in production yet.
|
|
|
|
|
|
|
|
Using Compose is basically a three-step process.
|
|
|
|
|
|
|
|
First, you define your app's environment with a `Dockerfile` so it can be
|
|
|
|
reproduced anywhere:
|
|
|
|
|
|
|
|
```Dockerfile
|
|
|
|
FROM python:2.7
|
|
|
|
WORKDIR /code
|
|
|
|
ADD requirements.txt /code/
|
|
|
|
RUN pip install -r requirements.txt
|
|
|
|
ADD . /code
|
|
|
|
CMD python app.py
|
|
|
|
```
|
2014-01-27 16:54:43 +01:00
|
|
|
|
2015-02-16 20:21:17 +01:00
|
|
|
Next, you define the services that make up your app in `docker-compose.yml` so
|
|
|
|
they can be run together in an isolated environment:
|
2013-12-09 13:01:15 +01:00
|
|
|
|
|
|
|
```yaml
|
2013-12-20 19:10:30 +01:00
|
|
|
web:
|
|
|
|
build: .
|
|
|
|
links:
|
|
|
|
- db
|
|
|
|
ports:
|
2014-02-20 13:53:43 +01:00
|
|
|
- "8000:8000"
|
2013-12-09 13:03:26 +01:00
|
|
|
db:
|
2014-08-07 23:48:29 +02:00
|
|
|
image: postgres
|
2013-12-09 13:01:15 +01:00
|
|
|
```
|
|
|
|
|
2015-02-16 20:21:17 +01:00
|
|
|
Lastly, run `docker-compose up` and Compose will start and run your entire app.
|
2013-12-31 17:31:40 +01:00
|
|
|
|
2015-02-16 20:21:17 +01:00
|
|
|
Compose has commands for managing the whole lifecycle of your application:
|
2013-12-31 17:31:40 +01:00
|
|
|
|
2015-02-16 20:21:17 +01:00
|
|
|
* Start, stop and rebuild services
|
|
|
|
* View the status of running services
|
|
|
|
* Stream the log output of running services
|
|
|
|
* Run a one-off command on a service
|
2013-12-31 17:31:40 +01:00
|
|
|
|
2014-01-27 19:11:27 +01:00
|
|
|
Installation and documentation
|
|
|
|
------------------------------
|
2014-01-02 15:55:48 +01:00
|
|
|
|
2015-02-25 19:25:15 +01:00
|
|
|
- Full documentation is available on [Docker's website](http://docs.docker.com/compose/).
|
|
|
|
- Hop into #docker-compose on Freenode if you have any questions.
|