介绍
Docker是一个很棒的工具,但要真正充分发挥其潜力,最好是应用程序的每个组件都在自己的容器中运行。对于具有大量组件的复杂应用程序,编排所有容器以一起启动和关闭(更不用说彼此交谈)可能很快变得难以处理。
Docker社区提出了一个名为Fig的流行解决方案,它允许您使用单个YAML文件来编排所有Docker容器和配置。这变得如此受欢迎,以至于Docker团队最终决定基于Fig源制作他们自己的版本。他们称之为Docker Compose。简而言之,它使得处理Docker容器的编排过程(例如启动,关闭和设置容器内链接和卷)非常容易。
在本文结束时,您将安装Docker和Docker Compose,并对Docker Compose的工作原理有基本的了解。
Docker和Docker撰写概念
使用Docker Compose需要将一堆不同的Docker概念合二为一,所以在我们开始之前,让我们花一点时间来回顾一下所涉及的各种概念。如果您已经熟悉Docker概念,如卷,链接和端口转发,那么您可能希望继续前进到下一部分。
Docker镜像
每个Docker容器都是Docker镜像的本地实例。您可以将Docker镜像视为完整的Linux安装。通常,最小安装仅包含运行映像所需的最少包。这些映像使用主机系统的内核,但由于它们在Docker容器内运行并且只能看到自己的文件系统,因此完全可以在Ubuntu主机上运行像CentOS这样的分发(反之亦然)。
大多数Docker镜像都是通过Docker Hub分发的,Docker Hub由Docker团队维护。大多数流行的开源项目都有相应的镜像上传到Docker Registry,您可以使用它来部署软件。在可能的情况下,最好抓住“官方”镜像,因为Docker团队保证他们遵循Docker最佳实践。
Docker镜像之间的通信
默认情况下,Docker容器与主机隔离,这意味着默认情况下主机无法访问Docker容器内的文件系统,也无法通过网络与其通信。毋庸置疑,这使得默认情况下配置和处理在Docker容器内运行的映像很困难。
Docker有三种主要方法可以解决这个问题。第一个也是最常见的是让Docker指定将在Docker容器中设置的环境变量。然后,在Docker容器内运行的代码将在启动时检查这些环境变量的值,并使用它们来正确配置自身。
另一种常用的方法是Docker数据卷)。Docker卷有两种形式 - 内部和共享。
指定内部卷只意味着对于为特定Docker容器指定的文件夹,数据将在删除容器时保留。例如,如果您想确保挂起的日志文件可能指定了内部
/var/log
卷。
共享卷将Docker容器内的文件夹映射到主机上的文件夹。这使您可以轻松地在Docker容器和主机之间共享文件。
与Docker容器通信的第三种方式是通过网络。Docker允许通过
links
端口转发在不同的Docker容器之间进行通信,允许您将Docker容器内的端口转发到主机服务器上的端口。例如,您可以创建一个链接,以允许您的WordPress和MariaDB Docker容器相互通信并进行端口转发,以便将WordPress暴露给外部世界,以便用户可以连接到它。
准备
要阅读本文,您需要具备以下条件:
- CentOS 7 腾讯云CVM
- 一台已经设置好可以使用
命令的非root账号的CentOS服务器,并且已开启防火墙。没有服务器的同学可以在这里购买,不过我个人更推荐您使用免费的腾讯云开发者实验室进行试验,学会安装后再购买服务器。sudo
第1步 - 安装Docker
首先,如果你还没有安装Docker。安装Docker的最快方法是下载并安装他们的安装脚本(系统会提示您输入sudo密码)。
wget -qO- https://get.docker.com/ | sh
复制
上面的命令下载并执行Docker团队编写的小型安装脚本。
如果未正确配置用户,使用Docker会很麻烦,因此请使用
docker
以下命令将用户添加到组中。
sudo usermod -aG docker $(whoami)
复制
注销并从服务器登录以激活新组。
将Docker设置为在引导时自动启动:
sudo systemctl enable docker.service
复制
最后,启动Docker服务:
sudo systemctl start docker.service
复制
第2步 - 安装Docker Compose
现在你已经安装了Docker,让我们继续安装Docker Compose。首先,安装
python-pip
为先决条件:
sudo yum install epel-release
sudo yum install -y python-pip
复制
然后你可以安装Docker Compose:
sudo pip install docker-compose
复制
您还需要在CentOS 7上升级Python包来获得
docker-compose
才能成功运行:
sudo yum upgrade python*
复制
第3步 - 使用Docker Compose运行容器
公共Docker注册表Docker Hub包含一个简单的Hello World镜像。现在我们已经安装了Docker Compose,让我们用这个非常简单的例子来测试它。
首先,为我们的YAML文件创建一个目录:
mkdir hello-world
复制
然后切换到目录:
cd hello-world
复制
现在使用您喜欢的文本编辑器创建YAML文件(我们将使用nano):
nano docker-compose.yml
复制
将以下内容放入文件,保存文件,然后退出文本编辑器:
my-test:
image: hello-world
复制
第一行将用作容器名称的一部分。第二行指定用于创建容器的镜像。该镜像将从官方Docker Hub存储库下载。
仍在
~/hello-world
目录中时,执行以下命令来创建容器:
docker-compose up
复制
输出应从以下开始:
Creating helloworld_my-test_1...
Attaching to helloworld_my-test_1
my-test_1 |
my-test_1 | Hello from Docker.
my-test_1 | This message shows that your installation appears to be working correctly.
my-test_1 |
复制
输出然后解释了Docker正在做什么:
- Docker客户端联系了Docker守护程序。
- Docker守护程序从Docker Hub中提取了“hello-world”镜像。
- Docker守护程序从该映像创建了一个新容器,该容器运行生成您当前正在读取的输出的可执行文件。
- Docker守护程序将该输出流式传输到Docker客户端,后者将其发送到您的终端。
如果该过程没有自行退出,请按
CTRL-C
。
这个简单的测试没有显示Docker Compose的主要优点之一 - 能够同时上下移动一组Docker容器。
第4步 - 学习Docker撰写命令
让我们回顾一下该
docker-compose
工具支持的命令。
该
docker-compose
命令基于每个目录工作。您可以在一台计算机上运行多组Docker容器 - 只需为每个容器创建一个目录,为其目录中的每个容器创建一个
docker-compose.yml
文件。
到目前为止,我们一直在运行
docker-compose up
并使用
CTRL-C
它来关闭它。这允许调试消息显示在终端窗口中。但这并不理想,在生产中运行时,您会希望
docker-compose
更像是服务。一种简单的方法是在会话
-d
时添加选项
up
:
docker-compose up -d
复制
docker-compose
现在将分叉到后台。
要显示您的Docker容器组(已停止且当前正在运行),请使用以下命令:
docker-compose ps
复制
例如,以下显示
helloworld_my-test_1
容器已停止:
Name Command State Ports
-----------------------------------------------
helloworld_my-test_1 /hello Exit 0
复制
正在运行的容器将显示
Up
状态:
Name Command State Ports
---------------------------------------------------------------
nginx_nginx_1 nginx -g daemon off; Up 443/tcp, 80/tcp
复制
要停止应用程序组的所有正在运行的Docker容器,请在用于启动Docker组的与
docker-compose.yml
文件相同的目录中发出以下命令:
docker-compose stop
复制
注意: 如果您需要更有力地关闭东西,也可以使用
docker-compose kill
。
在某些情况下,Docker容器会将其旧信息存储在内部卷中。如果要从头开始,可以使用该
rm
命令完全删除构成容器组的所有容器:
docker-compose rm
复制
如果您从包含Docker容器和
.yml
文件的目录以外的目录中尝试这些命令中的任何一个,它将会抱怨并且不会显示您的容器:
Can't find a suitable configuration file in this directory or any parent. Are you in the right directory?
Supported filenames: docker-compose.yml, docker-compose.yaml, fig.yml, fig.yaml
复制
第5步 - 访问Docker容器文件系统(可选)
如果需要在容器内部处理命令提示符,则可以使用该
docker exec
命令。
在世界,你好!示例在运行后退出,因此我们需要启动一个将继续运行的容器,以便我们可以使用它
docker exec
来访问容器的文件系统。我们来看看Docker Hub 中的Nginx镜像。
为它创建一个新目录并更改为:
mkdir ~/nginx && cd $_
复制
在我们的新目录中创建一个
docker-compose.yml
文件:
nano docker-compose.yml
复制
并粘贴如下:
nginx:
image: nginx
复制
保存文件并退出。我们只需要使用以下命令启动Nginx容器作为后台进程:
docker-compose up -d
复制
将下载Nginx镜像,然后在后台启动容器。
现在我们需要
CONTAINER ID
容器。正在运行的所有容器的列表:
docker ps
复制
您将看到类似于以下内容的内容:
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
e90e12f70418 nginx "nginx -g 'daemon off" 6 minutes ago Up 5 minutes 80/tcp, 443/tcp nginx_nginx_1
复制
注意:仅使用该命令列出正在运行的容器
docker ps
。
如果我们想对这个容器中的文件系统进行更改,我们将获取其ID(在此示例中是
e90e12f70418
)并用
docker exec
在容器内启动shell:
docker exec -it e90e12f70418 /bin/bash
复制
该
-t
选项打开一个终端,该
-i
选项使其具有交互性。这些
/bin/bash
选项为正在运行的容器打开一个bash shell。请务必使用容器的ID。
您将看到容器的bash提示符类似于:
root@e90e12f70418:/#
复制
从这里,您可以从命令提示符处工作。但请记住,除非您位于作为数据卷一部分保存的目录中,否则一旦容器重新启动,您的更改就会消失。另一个需要注意的是,大多数Docker镜像是使用非常少的Linux安装创建的,因此您习惯使用的某些命令行实用程序和工具可能不存在。
结论
太棒了,所以它涵盖了Docker Compose的基本概念以及如何安装和运行它。
有关该
docker-compose.yml
文件的配置选项的完整列表,请参阅Compose文件参考。
更多CentOS教程请前往腾讯云+社区学习更多知识。
参考文献:《How To Install and Use Docker Compose on CentOS 7》