准备工作
创建一个空的项目目录。
可以将目录命名为易于记忆的名称。此目录是应用程序映像的上下文。该目录应该只包含构建该图像的资源。在项目目录中创建一个名为Dockerfile的新文件。
Dockerfile 通过一个或多个配置该映像的构建命令定义应用程序的映像内容。构建后,您可以在容器中运行映像。将以下内容添加到Dockerfile。
1
2
3
4
5
6
7
8# syntax=docker/dockerfile:1
FROM python:3
ENV PYTHONDONTWRITEBYTECODE=1
ENV PYTHONUNBUFFERED=1
WORKDIR /code
COPY requirements.txt /code/
RUN pip install -r requirements.txt
COPY . /code/这个Dockerfile从Python3父图像开始。通过添加新code目录来修改父图像。通过安装requirements.txt文件中定义的 Python 要求进一步修改父映像。
保存并关闭Dockerfile。
在项目目录中创建一个requirements.txt文件。
此文件被Dockerfile中RUN pip install -r requirements.txt使用.在文件中添加所需的软件。
1
2Django>=3.0,<4.0
psycopg2>=2.8保存并关闭requirements.txt文件。
在项目目录中创建一个名为docker-compose.yml的文件。
该docker-compose.yml文件描述了制作您的应用程序的服务。
在此示例中,这些服务是 Web 服务器和数据库。
compose 文件还描述了这些服务使用哪些 Docker 映像、它们如何链接在一起、它们可能需要安装在容器内的任何卷。
最后,该docker-compose.yml文件描述了这些服务公开的端口。将以下配置添加到文件中。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24version: "3.9"
services:
db:
image: postgres
volumes:
- ./data/db:/var/lib/postgresql/data
environment:
- POSTGRES_DB=django
- POSTGRES_USER=django
- POSTGRES_PASSWORD=django
web:
build: .
command: python manage.py runserver 0.0.0.0:8000
volumes:
- .:/code
ports:
- "8000:8000"
environment:
- POSTGRES_NAME=django
- POSTGRES_USER=django
- POSTGRES_PASSWORD=django
depends_on:
- db该文件定义了两个服务:db服务和web服务。这里使用内置开发服务器在端口
8000
上运行应用程序,不要在生产环境中使用它。保存并关闭docker-compose.yml文件。
创建Django项目
切换到项目目录的根目录。
通过运行docker-compose run命令创建 Django 项目,如下所示。
1
sudo docker-compose run web django-admin startproject composeexample .
这指示 Compose使用服务的映像和配置django-admin startproject composeexample 在容器中运行。
web由于web图像尚不存在,Compose 从当前目录构建它,如build: ..docker-compose.yml
构建服务映像后web,Compose 将运行它并 django-admin startproject在容器中执行命令。
此命令指示 Django 创建一组代表 Django 项目的文件和目录。docker-compose命令完成后,执行
ls -l
命令列出项目的内容。
如果您在 Linux 上运行 Docker,则django-admin创建的文件归 root 所有。
发生这种情况是因为容器以 root 用户身份运行。
如果您在 Mac 或 Windows 上运行 Docker,您应该已经拥有所有文件的所有权,包括由 django-admin。更改新文件的所有权。
1
sudo chown -R $USER:$USER composeexample manage.py
请勿更改 Postgres 文件所在的 data 文件夹的权限,否则 Postgres 将因权限问题无法启动。
连接数据库
在您的项目目录中,编辑该composeexample/settings.py文件。
替换以下内容。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18# settings.py
import os
[...]
ALLOWED_HOSTS = ['*']
[...]
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.postgresql',
'NAME': os.environ.get('POSTGRES_NAME'),
'USER': os.environ.get('POSTGRES_USER'),
'PASSWORD': os.environ.get('POSTGRES_PASSWORD'),
'HOST': 'db',
'PORT': 5432,
}
}这些设置是由docker-compose.yml中指定的postgres Docker映像决定的。
保存并关闭文件。
从项目的顶级目录运行docker-compose up命令。
1
docker-compose up
此时,Django 应用程序应该在 Docker 主机上的
8000
端口上运行。在适用于 Mac 的 Docker Desktop 和适用于 Windows 的 Docker Desktop 上,Web 浏览器打开http://localhost:8000
以查看 Django 欢迎页面。列出正在运行的容器。
在另一个终端窗口中使用docker ps
或docker container ls
命令列出正在运行的 Docker 进程。使用以下任一方法关闭服务并进行清理:
- 在与启动项目的相同终端窗口键入
Ctrl-C
来停止应用程序: - 为了更优雅的关闭,切换到不同的终端窗口,然后在 Django 示例项目目录的顶层下运行
docker-compose down
。
- 在与启动项目的相同终端窗口键入