mirror of
				https://github.com/docker/compose.git
				synced 2025-10-31 11:14:02 +01:00 
			
		
		
		
	Merge pull request #1994 from charleswhchan/patch-3
Touchup "Quickstart Guide: Compose and Django"
This commit is contained in:
		
						commit
						bc82f065bc
					
				
							
								
								
									
										142
									
								
								docs/django.md
									
									
									
									
									
								
							
							
						
						
									
										142
									
								
								docs/django.md
									
									
									
									
									
								
							| @ -10,20 +10,30 @@ 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. | ||||
| 
 | ||||
| 1. Create an empty project directory. | ||||
| 
 | ||||
|     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. | ||||
| 
 | ||||
| 2. Create a new file called `Dockerfile` in your project directory. | ||||
| 
 | ||||
|     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/). | ||||
| 
 | ||||
| 3. Add the following content to the `Dockerfile`. | ||||
| 
 | ||||
|         FROM python:2.7 | ||||
|         ENV PYTHONUNBUFFERED 1 | ||||
| @ -33,21 +43,34 @@ Dockerfile consists of: | ||||
|         RUN pip install -r requirements.txt | ||||
|         ADD . /code/ | ||||
| 
 | ||||
| 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/). | ||||
|     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. | ||||
| 
 | ||||
| Second, you'll define your Python dependencies in a file called | ||||
| `requirements.txt`: | ||||
| 4. Save and close the `Dockerfile`. | ||||
| 
 | ||||
| 5. Create a `requirements.txt` in your project directory. | ||||
| 
 | ||||
|     This file is used by the `RUN pip install -r requirements.txt` command in your `Dockerfile`. | ||||
| 
 | ||||
| 6. Add the required software in the file. | ||||
| 
 | ||||
|         Django | ||||
|         psycopg2 | ||||
| 
 | ||||
| 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. | ||||
| 7. Save and close the `requirements.txt` file. | ||||
| 
 | ||||
| 8. Create a file called `docker-compose.yml` in your project directory. | ||||
| 
 | ||||
|     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. | ||||
| 
 | ||||
| 9. Add the following configuration to the file. | ||||
| 
 | ||||
|         db: | ||||
|           image: postgres | ||||
| @ -61,28 +84,42 @@ mounted inside the containers, and what ports they expose. | ||||
|           links: | ||||
|             - db | ||||
| 
 | ||||
| See the [`docker-compose.yml` reference](yml.md) for more information on how | ||||
| this file works. | ||||
|     This file defines two services: The `db` service and the `web` service. | ||||
| 
 | ||||
| ### Build the project | ||||
| 10. Save and close the `docker-compose.yml` file. | ||||
| 
 | ||||
| You can now start a Django project with `docker-compose run`: | ||||
| ## 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 . | ||||
| 
 | ||||
| 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. | ||||
|     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`. | ||||
| 
 | ||||
| This will generate a Django app inside the current directory: | ||||
|     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 | ||||
| ## Connect the database | ||||
| 
 | ||||
| Now you need to set up the database connection. Replace the `DATABASES = ...` | ||||
| definition in `composeexample/settings.py` to read: | ||||
| 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': { | ||||
| @ -95,39 +132,36 @@ definition in `composeexample/settings.py` to read: | ||||
|         } | ||||
| 
 | ||||
|     These settings are determined by the | ||||
| [postgres](https://registry.hub.docker.com/_/postgres/) Docker image specified | ||||
| in the Dockerfile. | ||||
|     [postgres](https://registry.hub.docker.com/_/postgres/) Docker image | ||||
|     specified in `docker-compose.yml`. | ||||
| 
 | ||||
| Then, run `docker-compose up`: | ||||
| 3. Save and close the file. | ||||
| 
 | ||||
|     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. | ||||
| 4. Run the `docker-compose up` command. | ||||
| 
 | ||||
| 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. | ||||
|         $ 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. | ||||
| 
 | ||||
| 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 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) | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user