在Ubuntu 16.04上安装Docker Compose的方法

简介: 在Ubuntu 16.04上安装Docker Compose的方法

简介

Docker 是一个用于自动化部署 Linux 应用程序的强大工具,它能够将应用程序部署在软件容器内,但要充分发挥其潜力,应用程序的每个组件都应该在自己独立的容器中运行。对于具有许多组件的复杂应用程序,编排所有容器一起启动、通信和关闭可能会变得非常棘手。

Docker 社区提出了一个流行的解决方案,叫做 Fig,它允许您使用单个 YAML 文件来编排所有 Docker 容器和配置。这变得非常受欢迎,以至于 Docker 团队决定基于 Fig 源代码制作 Docker Compose,而 Fig 现在已经被弃用。Docker Compose 让用户更容易地编排 Docker 容器的进程,包括启动、关闭和设置容器之间的链接和卷。

在本教程中,我们将向您展示如何安装最新版本的 Docker Compose,以帮助您管理多容器应用程序。

先决条件

要遵循本文,您需要一个安装了以下内容的 Ubuntu 16.04 服务器:

  • 一个具有 sudo 权限的非 root 用户(《在 Ubuntu 16.04 上进行初始服务器设置》解释了如何设置这一点。)
  • 通过《在 Ubuntu 16.04 上安装和使用 Docker》中的第 1 步第 2 步的说明安装了 Docker

一旦这些条件具备,您就可以开始跟着操作了。

步骤 1 — 安装 Docker Compose

虽然我们可以从官方的 Ubuntu 软件仓库安装 Docker Compose,但它的版本比最新发布的版本要落后一些,因此我们将从 Docker 的 GitHub 仓库安装 Docker Compose。下面的命令与您在发布页面上找到的命令略有不同。通过使用 -o 标志来指定输出文件,而不是重定向输出,这种语法避免了在使用 sudo 时遇到的权限被拒绝的错误。

我们将检查当前的发布版本,并在必要时在下面的命令中更新它:

sudo curl -L https://github.com/docker/compose/releases/download/1.18.0/docker-compose-`uname -s`-`uname -m` -o /usr/local/bin/docker-compose

接下来,我们将设置权限:

sudo chmod +x /usr/local/bin/docker-compose

然后,我们将通过检查版本来验证安装是否成功:

docker-compose --version

这将打印出我们安装的版本:

docker-compose version 1.18.0, build 8dd22a9

现在我们已经安装了 Docker Compose,可以运行一个“Hello World”示例了。

步骤 2 — 使用 Docker Compose 运行容器

公共 Docker 注册表 Docker Hub 包含一个用于演示和测试的 Hello World 镜像。它演示了使用 Docker Compose 运行容器所需的最小配置:一个调用单个镜像的 YAML 文件。

首先,我们将为 YAML 文件创建一个目录并进入该目录:

mkdir hello-world
cd hello-world

然后,我们将创建 YAML 文件:

nano docker-compose.yml

将以下内容放入文件中,保存文件并退出文本编辑器:

my-test:
 image: hello-world

YAML 文件中的第一行用作容器名称的一部分。第二行指定要使用哪个镜像来创建容器。当我们运行 docker-compose up 命令时,它将查找我们指定的名称为 hello-world 的本地镜像。有了这个设置,我们将保存并退出文件。

我们可以使用 docker images 命令手动查看系统上的镜像:

docker images

当没有本地镜像时,只会显示列标题:

REPOSITORY          TAG                 IMAGE ID            CREATED             SIZE

现在,仍然在 ~/hello-world 目录中,我们将执行以下命令:

docker-compose up

第一次运行该命令时,如果没有名为 hello-world 的本地镜像,Docker Compose 将从 Docker Hub 公共仓库中拉取它:

Pulling my-test (hello-world:latest)...
latest: Pulling from library/hello-world
c04b14da8d14: Downloading [==================================================>] c04b14da8d14: Extracting [==================================================>]  c04b14da8d14: Extracting [==================================================>]  c04b14da8d14: Pull complete
Digest: sha256:0256e8a36e2070f7bf2d0b0763dbabdd67798512411de4cdcf9431a1feb60fd9
Status: Downloaded newer image for hello-world:latest
. . .

拉取镜像后,docker-compose 创建一个容器,附加并运行 hello 程序,从而确认安装似乎工作正常:

. . .
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 |
. . .

然后它打印了它所做的事情的解释:

[secondary_label Output of docker-compose up]
1. Docker 客户端联系了 Docker 守护进程。
2. Docker 守护进程从 Docker Hub 拉取了 "hello-world" 镜像。
3. Docker 守护进程从该镜像创建了一个新的容器,运行了生成您当前正在阅读的输出的可执行文件。
4. Docker 守护进程将该输出流式传输到 Docker 客户端,后者将其发送到您的终端。

Docker 容器只在命令活动时运行,因此一旦 hello 运行结束,容器就会停止。因此,当我们查看活动进程时,列标题将会出现,但 hello-world 容器不会列出,因为它没有在运行。

docker ps
CONTAINER ID        IMAGE               COMMAND             CREATED             STATUS                      PORTS               NAMES

通过使用 -a 标志显示所有容器而不仅仅是活动的容器,我们可以看到容器信息,这在下一步中会用到:

docker ps -a
CONTAINER ID        IMAGE               COMMAND             CREATED             STATUS                      PORTS               NAMES
06069fd5ca23        hello-world         "/hello"            35 minutes ago      Exited (0) 35 minutes ago                       drunk_payne

这显示了我们在完成后需要删除容器的信息。

步骤 3 —— 移除镜像(可选)

为了避免使用不必要的磁盘空间,我们将移除本地镜像。为此,我们需要使用 docker rm 命令删除所有引用该镜像的容器,后面跟上容器的 CONTAINER ID 或 NAME。下面,我们将使用刚刚运行的 docker ps -a 命令中的 CONTAINER ID。请确保替换为您的容器的 ID:

docker rm 06069fd5ca23

一旦删除了所有引用该镜像的容器,我们就可以移除该镜像:

docker rmi hello-world

结论

我们已经安装了 Docker Compose,通过运行 Hello World 示例测试了我们的安装,并移除了测试镜像和容器。

虽然 Hello World 示例确认了我们的安装,但简单的配置并未展示 Docker Compose 的主要优势之一 —— 能够同时启动和关闭一组 Docker 容器。要看到 Docker Compose 的威力,您可能想看看这个实际示例:《如何在 Ubuntu 16.04 上使用 Docker 和 Docker Compose 配置持续集成测试环境》。


目录
相关文章
|
10天前
|
NoSQL Redis Docker
使用Docker Compose工具进行容器编排的教程
以上就是使用Docker Compose进行容器编排的基础操作。这能帮你更有效地在本地或者在服务器上部署和管理多容器应用。
126 11
|
7天前
|
Ubuntu Docker 容器
Ubuntu国内镜像Docker安装详细教程
Ubuntu国内镜像Docker安装详细教程
|
21天前
|
存储 NoSQL MongoDB
Docker中安装MongoDB并配置数据、日志、配置文件持久化。
现在,你有了一个运行在Docker中的MongoDB,它拥有自己的小空间,对高楼大厦的崩塌视而不见(会话丢失和数据不持久化的问题)。这个MongoDB的数据、日志、配置文件都会妥妥地保存在你为它精心准备的地方,天旋地转,它也不会失去一丁点儿宝贵的记忆(即使在容器重启后)。
107 4
|
1月前
|
Linux iOS开发 Docker
MyEMS开源系统安装之Linux/macOS上的DOcker
本指南详细介绍了如何在Linux/macOS上使用Docker部署MyEMS系统。主要内容包括:前置条件(如安装Docker、npm和MySQL),以及分步骤部署各个组件(如myems-api、myems-admin、myems-modbus-tcp等)。每个步骤涵盖源代码复制、环境配置、镜像构建、容器运行及日志管理等操作,并提供了多平台构建的支持。最后,指南还说明了默认端口和登录凭据,帮助用户快速启动并访问MyEMS的管理界面和Web界面。
76 1
|
存储 机器学习/深度学习 中间件
快速上手 Elasticsearch:Docker Compose 部署详解
本文介绍了如何使用Docker Compose快速搭建Elasticsearch学习环境。Elasticsearch是一款用于实时搜索和分析的分布式中间件,适用于多种场景,如搜索、日志分析、机器学习等。首先,创建docker网络,拉取最新版8.12.2镜像。接着,编写docker-compose.yml文件,配置单节点集群,设置端口映射、内存限制及数据卷挂载。然后,创建并配置数据卷目录,允许远程访问和跨域。最后,启动服务并验证,通过浏览器访问确认服务运行正常。本文为初学者提供了一个简便的Elasticsearch部署方法。
1277 4
快速上手 Elasticsearch:Docker Compose 部署详解
|
存储 数据可视化 数据安全/隐私保护
使用 Docker Compose 部署 Docker Registry
【1月更文挑战第2天】 在内网环境中,我们期望能够在本地共享镜像。为了解决这一问题,Docker Registry成为了我们的救星。Docker Registry是一个用于存储和管理Docker镜像的开源工具。通过在本地部署Docker Registry,您可以轻松地构建、存储和分享自己的Docker镜像。
656 3
使用 Docker Compose 部署 Docker Registry
|
Java Docker 微服务
如何使用Docker和Docker Compose部署微服务
【2月更文挑战第12天】
1028 0
|
8月前
|
运维 开发者 Docker
Docker Compose:简化容器化应用的部署与管理
Docker Compose:简化容器化应用的部署与管理
|
8月前
|
Docker 微服务 容器
使用Docker Compose实现微服务架构的快速部署
使用Docker Compose实现微服务架构的快速部署
202 1