Docker Compose 是一个与 Docker 原生集成的工具,让管理多容器应用程序变得轻而易举。
Docker Compose 提供的好处很多,其中包括:
- 轻松管理容器网络:通过 Docker 网络连接两个容器在 Docker Compose 中非常简单,就像定义一个网络并告诉容器连接到它一样简单,此外,Docker Compose 可以在您创建和销毁容器本身时自动创建和销毁网络。
- 容器依赖关系:你有一个 Docker 容器,它需要另一个 Docker 容器来启动和运行,比如一个数据库,Docker Compose 允许您为容器定义依赖项,要求依赖项启动并运行,然后才能启动其他任何操作。
- 可重复设置:由于容器设置将在创建任何内容之前定义,这允许设置的可重复性,从而更容易将它们转移到其他系统,虽然理论上你可以在 Bash 之类的东西中这样做,但它会使事情变得不那么灵活并且更难适应变化。
在 Linux 上安装 Docker Compose
Docker Compose 在大多数发行版存储库中都很容易获得。
您可以使用以下命令在基于Ubuntu 和 Debian 的发行版上安装 Docker Compose :
代码语言:txt复制sudo apt install docker-compose
在 Arch 和 Manjaro 上,您可以使用:
代码语言:txt复制sudo pacman -S docker-compose
在 Fedora 上,您可以使用 dnf 命令:
代码语言:txt复制sudo dnf install docker-compose
您可能需要在 CentOS 上安装 Docker Compose付出更多努力。
对于任何其他发行版,您始终可以查看安装文档以获取有关获取所需软件包的信息。
创建我们的第一个 Docker Compose 文件
本指南假定您已经熟悉并熟悉 docker CLI 工具,如果不是,请考虑这样做,否则您可能会遇到一堆简单的问题。
Docker Compose 文件存储在 name 下,当您在同一目录中docker-compose.yml运行命令时会自动找到。docker-compose你猜对了,它的语法采用 YAML 的形式。
我们将从一个创建 Nextcloud 实例的文件开始,然后回顾它实际上是如何做到的。
首先,您需要创建撰写文件。在系统上创建一个空目录,然后创建docker-compose.yml文件。
接下来,用以下内容填充文件:
代码语言:txt复制version: '3.5'
services:
nextcloud_app:
container_name: nextcloud_app
image: nextcloud
restart: unless-stopped
networks:
- nextcloud
ports:
- 80:80
volumes:
- ./data/app:/var/www/html
depends_on:
- nextcloud_mariadb
nextcloud_mariadb:
container_name: nextcloud_mariadb
image: mariadb
restart: unless-stopped
networks:
- nextcloud
volumes:
- ./data/mariadb:/var/lib/mysql
environment:
MARIADB_ROOT_PASSWORD: 'mariadb'
networks:
nextcloud:
name: nextcloud_docker_network
现在您只需要运行docker-compose up -d,您就可以使用 Docker 成功部署 Nextcloud 了。
这是Nextcloud的登录页面。
了解我们的 Docker Compose 文件
现在您已经看到该文件确实有效,让我们回顾一下文件的内容,以便您真正了解它到底在做什么。
“版本”标签
代码语言:txt复制version: '3.5'
首先,version标签。这只是指定 Docker Compose 文件格式的版本,因为不同的版本会有不同的语法,您通常希望将其保留为最新版本,但并非必须如此,如果您有一些旧文件,这会很有帮助。
“服务”标签
代码语言:txt复制services:
nextcloud_app:
container_name: nextcloud_app
image: nextcloud
restart: unless-stopped
networks:
- nextcloud
ports:
- 80:80
volumes:
- ./data/app:/var/www/html
depends_on:
- nextcloud_mariadb
nextcloud_mariadb:
container_name: nextcloud_mariadb
image: mariadb
restart: unless-stopped
networks:
- nextcloud
volumes:
- ./data/mariadb:/var/lib/mysql
environment:
MARIADB_ROOT_PASSWORD: 'mariadb'
接下来,您会看到services标签。这将启动docker-compose up -d运行时创建的所有应用程序的列表。
接下来我们开始列出我们的第一个容器,nextcloud_app. 这用作应用程序的标识符,可供其他 Docker Compose 命令使用,请注意,这不是容器本身的名称 - 在下一部分中指定。
现在,您开始定义有关容器的所有内容。以下是对所有字段含义的复习,但如果您已经了解 Docker,大多数字段应该是不言自明的:
- container_name: 定义容器的名称。等效于--name选项。
- image: 定义从容器中提取的图像。
- restart:定义容器的重启策略。相当于--restart。
- networks: 定义容器连接的网络。该网络可以创建,也可以已经存在。此值用作标识符,docker-compose而不是网络的实际名称(在networks标记部分中定义)。
- ports:定义容器可以连接的主机端口。相当于--publish。
- volumes:定义容器的体积。相当于--volume。
- environment:定义容器的环境变量。相当于--env。此选项支持两种语法类型。第一个是variable: value,这是这里使用的。如果您习惯了dockerCLI 语法,可能会更熟悉的另一个选项是- variable=value.
- depends_on:指定容器依赖项。这用于要求容器在其依赖项拥有之前不启动。这接受来自容器列表的值。(不是container_name!)
“网络”标签
代码语言:txt复制networks:
nextcloud:
name: nextcloud_docker_network
现在你到了networks标签。这用于定义我们networks为容器列出的网络。
在该networks部分中,您首先列出了在 下提供给网络的标识符services。在这里,那是nextcloud。
接下来,您定义可以用 看到的网络名称docker network ls。在这里,我们将其命名为nextcloud_docker_network。
如果您希望容器加入一个已经存在的网络,您可以使用以下语法,替换network_name为 Docker 网络的名称:
代码语言:txt复制networks:
nextcloud:
external: true
name: network_name
您可以将 yml 文件命名为任何名称,但在使用 docker-compose 命令时必须指定文件名,保持传统并将其命名为 docker-compose.yml 以保持命令简短。