这篇文章主要介绍“怎么使用Docker Compose构建复杂的多容器App”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“怎么使用Docker Compose构建复杂的多容器App”文章能帮助大家解决问题。
在构建容器过程中,一般需要重复运行一些命令, 如 docker build
,docker run
等等,这些命令有时冗长而复杂,逐个重复运行这些命令十分繁琐,对于多容器的复杂应用尤其如此。使用 Docker Compose 工具能极大地简化容器的创建、管理和维护。
Docker Compose 工具相当于 C/C++ 的 make
工具,使用 make
需要 Makefile
,所有的编译链接设置都在Makefile
中指定,不需要为了运行程序而每次都在终端手动输入长串的指令。
Docker Compose 同样也需要一个配置文件: docker-compose.yaml
(文件扩展名也可以是 yml
).
YAML 是一种人类可读的数据序列化语言,通常用于配置文件和存储或传输数据的应用程序,YAML 使用 python 那样的缩进以指示嵌套关系。缩进通常使用两个空格,但是实际上没有限制,同 python,使用 #
表示注释。
如下是一个 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:
docker-compose up
docker-compose up
默认以附加模式运行,如果需要以分离模式运行则在命令后加 -d
:
docker-compose up -d
也因为此原因,docker-compose.yaml
里没有设置 -d
的选项。
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”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注亿速云行业资讯频道,小编每天都会为大家更新不同的知识点。
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。