怎么使用Docker Compose构建复杂的多容器App
这篇文章主要介绍"怎么使用Docker Compose构建复杂的多容器App"的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇"怎么使用Docker Compose构建复杂的多容器App"文章能帮助大家解决问题。
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"的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注行业资讯频道,小编每天都会为大家更新不同的知识点。