Mac Docker 创建第一个Django 应用,Part 1
2017-10-03 本文已影响24人
思考的虫子
Mac Docker 创建第一个Django 应用,Part 2
用Mac快速构建Django 容器 [摘录译]
原文:Quickstart: Compose and Django
这篇文章将指导你如何用Docker Compose 配置和启动一个简单的 Django + PostgreSQL 应用。请先确保您已安装Compose:
Install Docker Compose
定义您的项目组件
您需要创建一个Dockerfile 和一个Python 依赖文件,以及一个docker-compose.yml文件
- 创建一个项目目录
- 创建一个心的Dockerfile在当前项目目录下
- 添加内容到Dockerfile
FROM python:3
ENV PYTHONUNBUFFERED 1
RUN mkdir /code
WORKDIR /code
ADD requirements.txt /code/
RUN pip install -r requirements.txt
ADD . /code/
- 保存Dockerfile
- 创建一个 requirements.txt
Dockerfile 中的RUN pip install -r requirements.txt
将会用到它 - 添加所需的软件到requirements.txt
Django>=1.8,<2.0
psycopg2
- 保存requirements.txt
- 创建一个docker-compose.yml
docker-compose.yml文件里描述了您的app所需要的服务。compose一词我认为翻译为编制更恰当。在这里我们需要一个web服务器,一个数据服务器。编制文件指明了我们这些服务所用的镜像,他们如何连接,哪些卷要挂载到容器。最后定义服务端口。
version: '3'
services:
db:
image: postgres
web:
build: .
command: python3 manage.py runserver 0.0.0.0:8000
volumes:
- .:/code
ports:
- "8000:8000"
depends_on:
- db
- 保存 docker-compose.yml
创建一个Django项目
- 转到项目根目录
- 用docker-compose 创建项目
docker-compose run web django-admin.py startproject composeexample .
docker将启动web容器,并在里面执行 django-admin.py startproject composeexample,因为web镜像不存在所以compose先从当前目录建立它,见 build: 因为挂在了当前目录,所以新创建的项目文件在docker-compose run
执行完推出后可以看到
- ls 项目目录
$ ls -l
drwxr-xr-x 2 root root composeexample
-rw-rw-r-- 1 user user docker-compose.yml
-rw-rw-r-- 1 user user Dockerfile
-rwxr-xr-x 1 root root manage.py
-rw-rw-r-- 1 user user requirements.txt
连接数据库
- 打开composeexample/settings.py
- 替换DATABASE = …项
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.postgresql',
'NAME': 'postgres',
'USER': 'postgres',
'HOST': 'db',
'PORT': 5432,
}
}
这些参数是根据docker-compose.yml所指定的postgres Docker 镜像决定的。
- 保存
- 执行docker-compose up
$ docker-compose up
djangosample_db_1 is up-to-date
Creating djangosample_web_1 ...
Creating djangosample_web_1 ... done
Attaching to djangosample_db_1, djangosample_web_1
db_1 | The files belonging to this database system will be owned by user "postgres".
db_1 | This user must also own the server process.
db_1 |
db_1 | The database cluster will be initialized with locale "en_US.utf8".
db_1 | The default database encoding has accordingly been set to "UTF8".
db_1 | The default text search configuration will be set to "english".
. . .
web_1 | May 30, 2017 - 21:44:49
web_1 | Django version 1.11.1, using settings 'composeexample.settings'
web_1 | Starting development server at http://0.0.0.0:8000/
web_1 | Quit the server with CONTROL-C.
此时,你的Django app应该运行在8000端口上了。浏览器打开http://localhost:8000应该能看到
- 列出所有容器:
$ docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
def85eff5f51 django_web "python3 manage.py..." 10 minutes ago Up 9 minutes 0.0.0.0:8000->8000/tcp django_web_1
678ce61c79cc postgres "docker-entrypoint..." 20 minutes ago Up 9 minutes 5432/tcp django_db_1
- 关闭容器
Ctrl-C
或者新开一个terminal执行:docker-compose down