|
@@ -10,124 +10,158 @@ weight=4
|
|
|
<![end-metadata]-->
|
|
|
|
|
|
|
|
|
-## Quickstart Guide: Compose and Django
|
|
|
+# Quickstart Guide: Compose and Django
|
|
|
|
|
|
-
|
|
|
-This Quick-start Guide will demonstrate how to use Compose to set up and run a
|
|
|
+This quick-start guide demonstrates how to use Compose to set up and run a
|
|
|
simple Django/PostgreSQL app. Before starting, you'll need to have
|
|
|
[Compose installed](install.md).
|
|
|
|
|
|
-### Define the project
|
|
|
+## Define the project components
|
|
|
|
|
|
-Start by setting up the three files you'll need to build the app. First, since
|
|
|
-your app is going to run inside a Docker container containing all of its
|
|
|
-dependencies, you'll need to define exactly what needs to be included in the
|
|
|
-container. This is done using a file called `Dockerfile`. To begin with, the
|
|
|
-Dockerfile consists of:
|
|
|
+For this project, you need to create a Dockerfile, a Python dependencies file,
|
|
|
+and a `docker-compose.yml` file.
|
|
|
|
|
|
- FROM python:2.7
|
|
|
- ENV PYTHONUNBUFFERED 1
|
|
|
- RUN mkdir /code
|
|
|
- WORKDIR /code
|
|
|
- ADD requirements.txt /code/
|
|
|
- RUN pip install -r requirements.txt
|
|
|
- ADD . /code/
|
|
|
+1. Create an empty project directory.
|
|
|
|
|
|
-This Dockerfile will define an image that is used to build a container that
|
|
|
-includes your application and has Python installed alongside all of your Python
|
|
|
-dependencies. For more information on how to write Dockerfiles, see the
|
|
|
-[Docker user guide](https://docs.docker.com/userguide/dockerimages/#building-an-image-from-a-dockerfile) and the [Dockerfile reference](http://docs.docker.com/reference/builder/).
|
|
|
+ You can name the directory something easy for you to remember. This directory is the context for your application image. The directory should only contain resources to build that image.
|
|
|
|
|
|
-Second, you'll define your Python dependencies in a file called
|
|
|
-`requirements.txt`:
|
|
|
+2. Create a new file called `Dockerfile` in your project directory.
|
|
|
|
|
|
- Django
|
|
|
- psycopg2
|
|
|
+ The Dockerfile defines an application's image content via one or more build
|
|
|
+ commands that configure that image. Once built, you can run the image in a
|
|
|
+ container. For more information on `Dockerfiles`, see the [Docker user
|
|
|
+ guide](https://docs.docker.com/userguide/dockerimages/#building-an-image-from-a-dockerfile)
|
|
|
+ and the [Dockerfile reference](http://docs.docker.com/reference/builder/).
|
|
|
|
|
|
-Finally, this is all tied together with a file called `docker-compose.yml`. It
|
|
|
-describes the services that comprise your app (here, a web server and database),
|
|
|
-which Docker images they use, how they link together, what volumes will be
|
|
|
-mounted inside the containers, and what ports they expose.
|
|
|
+3. Add the following content to the `Dockerfile`.
|
|
|
|
|
|
- db:
|
|
|
- image: postgres
|
|
|
- web:
|
|
|
- build: .
|
|
|
- command: python manage.py runserver 0.0.0.0:8000
|
|
|
- volumes:
|
|
|
- - .:/code
|
|
|
- ports:
|
|
|
- - "8000:8000"
|
|
|
- links:
|
|
|
- - db
|
|
|
+ FROM python:2.7
|
|
|
+ ENV PYTHONUNBUFFERED 1
|
|
|
+ RUN mkdir /code
|
|
|
+ WORKDIR /code
|
|
|
+ ADD requirements.txt /code/
|
|
|
+ RUN pip install -r requirements.txt
|
|
|
+ ADD . /code/
|
|
|
|
|
|
-See the [`docker-compose.yml` reference](yml.md) for more information on how
|
|
|
-this file works.
|
|
|
+ This `Dockerfile` starts with a Python 2.7 base image. The base image is
|
|
|
+ modified by adding a new `code` directory. The base image is further modified
|
|
|
+ by installing the Python requirements defined in the `requirements.txt` file.
|
|
|
|
|
|
-### Build the project
|
|
|
+4. Save and close the `Dockerfile`.
|
|
|
|
|
|
-You can now start a Django project with `docker-compose run`:
|
|
|
+5. Create a `requirements.txt` in your project directory.
|
|
|
|
|
|
- $ docker-compose run web django-admin.py startproject composeexample .
|
|
|
+ This file is used by the `RUN pip install -r requirements.txt` command in your `Dockerfile`.
|
|
|
|
|
|
-First, Compose will build an image for the `web` service using the `Dockerfile`.
|
|
|
-It will then run `django-admin.py startproject composeexample .` inside a
|
|
|
-container built using that image.
|
|
|
+6. Add the required software in the file.
|
|
|
|
|
|
-This will generate a Django app inside the current directory:
|
|
|
+ Django
|
|
|
+ psycopg2
|
|
|
|
|
|
- $ ls
|
|
|
- Dockerfile docker-compose.yml composeexample manage.py requirements.txt
|
|
|
+7. Save and close the `requirements.txt` file.
|
|
|
|
|
|
-### Connect the database
|
|
|
+8. Create a file called `docker-compose.yml` in your project directory.
|
|
|
|
|
|
-Now you need to set up the database connection. Replace the `DATABASES = ...`
|
|
|
-definition in `composeexample/settings.py` to read:
|
|
|
+ The `docker-compose.yml` file describes the services that make your app. In
|
|
|
+ this example those services are a web server and database. The compose file
|
|
|
+ also describes which Docker images these services use, how they link
|
|
|
+ together, any volumes they might need mounted inside the containers.
|
|
|
+ Finally, the `docker-compose.yml` file describes which ports these services
|
|
|
+ expose. See the [`docker-compose.yml` reference](yml.md) for more
|
|
|
+ information on how this file works.
|
|
|
|
|
|
- DATABASES = {
|
|
|
- 'default': {
|
|
|
- 'ENGINE': 'django.db.backends.postgresql_psycopg2',
|
|
|
- 'NAME': 'postgres',
|
|
|
- 'USER': 'postgres',
|
|
|
- 'HOST': 'db',
|
|
|
- 'PORT': 5432,
|
|
|
- }
|
|
|
- }
|
|
|
+9. Add the following configuration to the file.
|
|
|
+
|
|
|
+ db:
|
|
|
+ image: postgres
|
|
|
+ web:
|
|
|
+ build: .
|
|
|
+ command: python manage.py runserver 0.0.0.0:8000
|
|
|
+ volumes:
|
|
|
+ - .:/code
|
|
|
+ ports:
|
|
|
+ - "8000:8000"
|
|
|
+ links:
|
|
|
+ - db
|
|
|
+
|
|
|
+ This file defines two services: The `db` service and the `web` service.
|
|
|
+
|
|
|
+10. Save and close the `docker-compose.yml` file.
|
|
|
+
|
|
|
+## Create a Django project
|
|
|
+
|
|
|
+In this step, you create a Django started project by building the image from the build context defined in the previous procedure.
|
|
|
+
|
|
|
+1. Change to the root of your project directory.
|
|
|
+
|
|
|
+2. Create the Django project using the `docker-compose` command.
|
|
|
+
|
|
|
+ $ docker-compose run web django-admin.py startproject composeexample .
|
|
|
|
|
|
-These settings are determined by the
|
|
|
-[postgres](https://registry.hub.docker.com/_/postgres/) Docker image specified
|
|
|
-in the Dockerfile.
|
|
|
+ This instructs Compose to run `django-admin.py startproject composeeexample`
|
|
|
+ in a container, using the `web` service's image and configuration. Because
|
|
|
+ the `web` image doesn't exist yet, Compose builds it from the current
|
|
|
+ directory, as specified by the `build: .` line in `docker-compose.yml`.
|
|
|
+
|
|
|
+ Once the `web` service image is built, Compose runs it and executes the
|
|
|
+ `django-admin.py startproject` command in the container. This command
|
|
|
+ instructs Django to create a set of files and directories representing a
|
|
|
+ Django project.
|
|
|
+
|
|
|
+3. After the `docker-compose` command completes, list the contents of your project.
|
|
|
+
|
|
|
+ $ ls
|
|
|
+ Dockerfile docker-compose.yml composeexample manage.py requirements.txt
|
|
|
+
|
|
|
+## Connect the database
|
|
|
+
|
|
|
+In this section, you set up the database connection for Django.
|
|
|
+
|
|
|
+1. In your project dirctory, edit the `composeexample/settings.py` file.
|
|
|
+
|
|
|
+2. Replace the `DATABASES = ...` with the following:
|
|
|
+
|
|
|
+ DATABASES = {
|
|
|
+ 'default': {
|
|
|
+ 'ENGINE': 'django.db.backends.postgresql_psycopg2',
|
|
|
+ 'NAME': 'postgres',
|
|
|
+ 'USER': 'postgres',
|
|
|
+ 'HOST': 'db',
|
|
|
+ 'PORT': 5432,
|
|
|
+ }
|
|
|
+ }
|
|
|
|
|
|
-Then, run `docker-compose up`:
|
|
|
+ These settings are determined by the
|
|
|
+ [postgres](https://registry.hub.docker.com/_/postgres/) Docker image
|
|
|
+ specified in `docker-compose.yml`.
|
|
|
|
|
|
- Recreating myapp_db_1...
|
|
|
- Recreating myapp_web_1...
|
|
|
- Attaching to myapp_db_1, myapp_web_1
|
|
|
- myapp_db_1 |
|
|
|
- myapp_db_1 | PostgreSQL stand-alone backend 9.1.11
|
|
|
- myapp_db_1 | 2014-01-27 12:17:03 UTC LOG: database system is ready to accept connections
|
|
|
- myapp_db_1 | 2014-01-27 12:17:03 UTC LOG: autovacuum launcher started
|
|
|
- myapp_web_1 | Validating models...
|
|
|
- myapp_web_1 |
|
|
|
- myapp_web_1 | 0 errors found
|
|
|
- myapp_web_1 | January 27, 2014 - 12:12:40
|
|
|
- myapp_web_1 | Django version 1.6.1, using settings 'composeexample.settings'
|
|
|
- myapp_web_1 | Starting development server at http://0.0.0.0:8000/
|
|
|
- myapp_web_1 | Quit the server with CONTROL-C.
|
|
|
+3. Save and close the file.
|
|
|
|
|
|
-Your Django app should nw be running at port 8000 on your Docker daemon. If you are using a Docker Machine VM, you can use the `docker-machine ip MACHINE_NAME` to get the IP address.
|
|
|
+4. Run the `docker-compose up` command.
|
|
|
|
|
|
-You can also run management commands with Docker. To set up your database, for
|
|
|
-example, run `docker-compose up` and in another terminal run:
|
|
|
+ $ docker-compose up
|
|
|
+ Starting composepractice_db_1...
|
|
|
+ Starting composepractice_web_1...
|
|
|
+ Attaching to composepractice_db_1, composepractice_web_1
|
|
|
+ ...
|
|
|
+ db_1 | PostgreSQL init process complete; ready for start up.
|
|
|
+ ...
|
|
|
+ db_1 | LOG: database system is ready to accept connections
|
|
|
+ db_1 | LOG: autovacuum launcher started
|
|
|
+ ..
|
|
|
+ web_1 | Django version 1.8.4, using settings 'composeexample.settings'
|
|
|
+ web_1 | Starting development server at http://0.0.0.0:8000/
|
|
|
+ web_1 | Quit the server with CONTROL-C.
|
|
|
|
|
|
- $ docker-compose run web python manage.py syncdb
|
|
|
+ At this point, your Django app should be running at port `8000` on your
|
|
|
+ Docker host. If you are using a Docker Machine VM, you can use the
|
|
|
+ `docker-machine ip MACHINE_NAME` to get the IP address.
|
|
|
|
|
|
## More Compose documentation
|
|
|
|
|
|
- [User guide](../index.md)
|
|
|
- [Installing Compose](install.md)
|
|
|
-- [Get started with Django](django.md)
|
|
|
- [Get started with Rails](rails.md)
|
|
|
- [Get started with WordPress](wordpress.md)
|
|
|
- [Command line reference](./reference/index.md)
|
|
|
-- [Yaml file reference](yml.md)
|
|
|
+- [YAML file reference](yml.md)
|