在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 配置持续集成测试环境》。


目录
相关文章
|
17天前
|
Prometheus 监控 Cloud Native
基于Docker安装Grafana和Prometheus
Grafana 是一款用 Go 语言开发的开源数据可视化工具,支持数据监控和统计,并具备告警功能。通过 Docker 部署 Grafana 和 Prometheus,可实现系统数据的采集、展示和告警。默认登录用户名和密码均为 admin。配置 Prometheus 数据源后,可导入主机监控模板(ID 8919)进行数据展示。
51 2
|
19天前
|
消息中间件 Linux RocketMQ
在Red Hat Enterprise Linux 9上使用Docker快速安装并部署
通过以上步骤,你可以在Red Hat Enterprise Linux 9上使用Docker快速安装并部署RocketMQ。这种方法不仅简化了安装过程,还提供了一个灵活的环境来管理和扩展消息队列系统。RocketMQ作为一款高性能的分布式消息系统,通过Docker可以实现快速部署和高效管理。
46 2
|
7天前
|
Docker 容器
【赵渝强老师】使用二进制包方式安装Docker
本文介绍了在企业生产环境中无法直接访问外网时,如何使用Docker官方提供的二进制包进行Docker的离线安装。文章详细列出了从安装wget、下载Docker安装包、解压、复制命令到启动Docker服务的具体步骤,并提供了相关命令和示例图片。最后,还介绍了如何设置Docker为开机自启模式。
|
7天前
|
缓存 Ubuntu Linux
如何安装Docker
如何安装Docker
64 0
|
5天前
|
Kubernetes Cloud Native Docker
云原生时代的容器化实践:Docker和Kubernetes入门
【10月更文挑战第37天】在数字化转型的浪潮中,云原生技术成为企业提升敏捷性和效率的关键。本篇文章将引导读者了解如何利用Docker进行容器化打包及部署,以及Kubernetes集群管理的基础操作,帮助初学者快速入门云原生的世界。通过实际案例分析,我们将深入探讨这些技术在现代IT架构中的应用与影响。
22 2
|
3天前
|
运维 Cloud Native 虚拟化
一文吃透云原生 Docker 容器,建议收藏!
本文深入解析云原生Docker容器技术,涵盖容器与Docker的概念、优势、架构设计及应用场景等,建议收藏。关注【mikechen的互联网架构】,10年+BAT架构经验倾囊相授。
一文吃透云原生 Docker 容器,建议收藏!
|
11天前
|
关系型数据库 MySQL API
|
7天前
|
运维 持续交付 Docker
深入理解Docker容器化技术
深入理解Docker容器化技术
|
4天前
|
缓存 监控 开发者
掌握Docker容器化技术:提升开发效率的利器
在现代软件开发中,Docker容器化技术成为提升开发效率和应用部署灵活性的重要工具。本文介绍Docker的基本概念,并分享Dockerfile最佳实践、容器网络配置、环境变量和秘密管理、容器监控与日志管理、Docker Compose以及CI/CD集成等技巧,帮助开发者更高效地利用Docker。
|
5天前
|
监控 持续交付 Docker
Docker 容器化部署在微服务架构中的应用有哪些?
Docker 容器化部署在微服务架构中的应用有哪些?