1 为什么需要 Docker Compose
在构建容器过程中,一般需要重复运行一些命令, 如 docker build
,docker run
等等,这些命令有时冗长而复杂,逐个重复运行这些命令十分繁琐,对于多容器的复杂应用尤其如此。使用 Docker Compose 工具能极大地简化容器的创建、管理和维护。
2 什么是 Docker Compose
Docker Compose 工具相当于 C/C++ 的 make
工具,使用 make
需要 Makefile
,所有的编译链接设置都在Makefile
中指定,不需要为了运行程序而每次都在终端手动输入长串的指令。
Docker Compose 同样也需要一个配置文件: docker-compose.yaml
(文件扩展名也可以是 yml
).
YAML 是一种人类可读的数据序列化语言,通常用于配置文件和存储或传输数据的应用程序,YAML 使用 python 那样的缩进以指示嵌套关系。缩进通常使用两个空格,但是实际上没有限制,同 python,使用 #
表示注释。
3 Docker Compose 的使用
如下是一个 Mern Stack App 项目结构:
docker-compose.yaml
文件内容如下:
# docker compose 规范的版本,下面的网站可查
# https://docs.docker.com/compose/compose-file/compose-versioning/
version: "3.8"
# 此 mern 将创建3个容器,下面的3个服务
# mongodb, backend, frontend 将自动被翻译成3个容器
services:
mongodb:
# 从 hub.docker.com 获取官方image
image: "mongo"
# 命名卷: 持久化保存数据库数据
volumes:
- data:/data/db
# 环境变量,在文件 ./env/mongo.env 里保存
env_file:
- ./env/mongo.env
backend:
build: ./backend
ports:
- "80:80"
volumes:
# 命名卷
- logs:/app/logs
# 绑定挂载,不同于命令,此文件中可以使用相对路径,
# 手动运行命令则需绝对路径
- ./backend:/app
# 匿名卷
- /app/node_modules
env_file:
- ./env/backend.env
depends_on:
- mongodb
frontend:
build: ./frontend
ports:
- "3000:3000"
volumes:
- ./frontend/src:/app/src
# stdin_open 和 tty 对应手动执行命令时的 -it
stdin_open: true
tty: true
# 仅仅在容器 backend 运行后,才会运行此 frontend
depends_on:
- backend
-
# 这里是整个 App 的命名卷
# 匿名卷和 bind-mounts 不能在这里指定
volumes:
data:
logs:
3.1 启动容器
docker-compose up
docker-compose up
默认以附加模式运行,如果需要以分离模式运行则在命令后加 -d
:
docker-compose up -d
也因为此原因,docker-compose.yaml
里没有设置 -d
的选项。
3.2 停止并删除容器
docker-compose down
- 使用 Docker Compose,
Dockerfile
文件仍然必不可少。 Docker Compose创建一个默认网络并将所有容器添加到该网络,故docker-compose.yaml
里不需要指定网络。 - docker-compose down 将停止并删除容器,因此 docker-compose.yaml 没有选项
--rm
不管是单容器还是多容器,使用 Docker Compose 能极大简化容器的创建、管理和维护,由此可见,Docker Compose 是一个强大的非常有用的工具。
到此这篇关于使用 Docker Compose 构建复杂的多容器 App的文章就介绍到这了,更多相关Docker Compose 多容器内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!