什么是docker-compose?和Dockerfile有什么
docekr compose
今天来介绍一下什么是docker compose
Compose是一款可以定义和运行多容器的dcoker应用,通过使用Compose,我们可以编辑YAML文件去配置我们的应用服务,只需要一条命令,就能将我们在配置文件中写好的服务全部启动。
先来看看使用Compose的优点吧,这里简单的介绍一下官方列举的几种场景:
在单主机上进行多环境隔离
- Compose使用项目名去将环境隔离开来,我们可以在以下场景应用项目名
- 在开发人员主机上,创建单个环境的多个副本(例如本次的需求已经进入测试阶段了,这部分代码最好保留着,但下一个需求进来了我们在原有基础上继续开发)
- 在共享主机或开发人员主机上,防止互相干扰,使用项目名称设置为唯一的编号
- 创建容器时保留卷数据
- Compose会保存你服务所需要的所有的卷,当运行docker-compose up的时候,如果它发现了任何以前运行过的容器,他会将卷从旧的容器复制进入新的容器,该过程确保数据不会丢失
仅重新创建已更改的容器 - Compose缓存了用于创建容器的配置,重新启动未更改的服务时,Compose将重新使用现有的容器,重复使用容器的意义在于我们可以高效的对环境进行配置和更改。(然而在我工作的实际环境中,有时候环境由不得开发人员。。。。)
使用Compose永远记住这三步
- 使用Dockerfile定义用用程序的环境,以便在任何地方可以复用。
- 在docker-compose.yml文件中定义组成你应用的各种服务,所以它们可以在一个隔离的环境中运行。
- 运行docker-compose up 然后Compose会启动并运行你的整个应用程序。
快速教程,使用Compose来部署Django
官方给的教程演示了如何使用docker Compose 快速配置和运行一个Django/PostgreSQL应用,在学习之前,请确保先安装了Compose。
首先我们需要创建一个Dockerfile,一个Python依赖文件,一个docker-compose.yml文件(.yml和.yaml拓展名都是可以的)
- 创建一个空项目目录。
起一个好记住的名字,目录会包含所有构建镜像的资源。 - 创建一个叫做Dockerfile的新文件在上面创建的项目目录中。
该Dockerfile定义了镜像的内容,通过写在内部的一条或多条命令。如果想查看更多关于Dockerfile的信息,大家可以看这篇文章。 - 在Dockerfile中写入以下内容。
FROM python:3
ENV PYTHONUNBUFFERED=1
WORKDIR /code
COPY requirements.txt /code/
RUN pip install -r requirements.txt
COPY . /code/
这里使用了以python3为基础的镜像,镜像的环境会在我们安装了python依赖后改变
- 保存Dockerfile
- 创建requirements.txt在我们上面创建的目录中
该文件会在运行Dockerfile时被用到,可以参考上面dockerfile中的内容
RUN pip install -r requirements.txt
- 在requirements.txt中写入下列内容
Django>=3.0,<4.0
psycopg2-binary>=2.8
- 保存requirements.txt文件
- 创建docker-compose.yml文件
docker-compose.yml文件描述了组成你应用的服务,这这个例子中这些服务分别是web服务器和数据库,compose文件同样也写了服务应用了哪些docker镜像,以及他们如何协同工作的。比如是否需要共用数据卷,关于更多的docker-compsose.yml的写法可以参考官方文档,根据自己的需求来写。 - 在docker-compose.yml中填写如下内容
version: "3.9"
services:
db:
image: postgres
environment:
- POSTGRES_DB=postgres
- POSTGRES_USER=postgres
- POSTGRES_PASSWORD=postgres
web:
build: .
command: python manage.py runserver 0.0.0.0:8000
volumes:
- .:/code
ports:
- "8000:8000"
depends_on:
- db
- 保存和关闭docker-compose.yml文件
到目前为止,我们已经准备好了使用docker-compose.yml部署django项目的所有准备工作,那么熟悉django的同学应该知道,我们还需要通过django的命令来创建我们的django项目,除此之外还需要配置数据库。
创建一个django项目
在项目目录下运行以下命令
sudo docker-compose run web django-admin startproject composeexample .
该命令会创建我们的django应用,在执行完商民的命令之后执行ls命令就能看到我们的django项目了。
之后的链接数据库的部分就不介绍了。
之后如果我们想好好的关闭我们的服务,可以在使用
docker-compose down
在项目的根目录,之后我们就可以安全的删除django项目了
总结
其实,通过这个简单的例子,再对比docker-compose.yml和Dockerfile这俩个文件的话。可以看出其中的区别,Dockerfile的目的更多的是用来创建和准备一个需要的工作环境,比如再Dockerfile中我们需要指定一个大致的镜像需求作为基底。例如我们需要python3的环境,就可以使用python3的镜像进一步的定制,安装需求,做出我们自己要的镜像来。
而我们再docker-compose.yml文件中看到,它内部虽然也可以直接指定镜像来组成我们的服务,但他更多的作用在多容器协同,也就是服务的编排和整体配置。所以说dockerfile和docekr-compose.yml的应用场景还是区别比较大的。
reference:
https://docs.docker.com/compose/#features
https://docs.docker.com/compose/django/
本文转载至
- Post author:SHIWEI MO
- Post link: https://mirrorgo.top/dcoker_compose/
- Copyright Notice: All articles in this blog are licensed under BY-NC-SA unless stating additionally.