如何在 Ubuntu 20.04 上安装和使用 Docker Compose

简介: 如何在 Ubuntu 20.04 上安装和使用 Docker Compose

介绍

Docker 简化了在容器中管理应用程序进程的过程。虽然容器在某些方面类似于虚拟机,但它们更轻量且更节省资源。这使开发人员能够将应用程序环境分解为多个隔离的服务。

对于依赖于多个服务的应用程序,编排所有容器一起启动、通信和关闭可能会变得非常复杂。Docker Compose 是一个工具,允许您根据 YAML 文件中设置的定义来运行基于多个容器的应用程序环境。它使用服务定义来构建完全可定制的环境,其中包含多个可以共享网络和数据卷的容器。

在本指南中,您将演示如何在 Ubuntu 20.04 服务器上安装 Docker Compose 以及如何开始使用这个工具。

先决条件

要遵循本文,您需要:

  • 作为非根用户具有 sudo 权限的 Ubuntu 20.04 本地机器或开发服务器的访问权限。如果您使用远程服务器,建议安装活动防火墙。要设置这些,请参考我们的 Ubuntu 20.04 初始服务器设置指南。
  • 在服务器或本地机器上安装了 Docker,按照《在 Ubuntu 20.04 上安装和使用 Docker》的 步骤 1 和 2 进行操作。

步骤 1 — 安装 Docker Compose

为了确保获得最新的稳定版本的 Docker Compose,您将从其官方 Github 存储库下载此软件。

首先,确认其发布页面上的最新版本。在撰写本文时,最新的稳定版本是 1.29.2

以下命令将下载 1.29.2 版本,并将可执行文件保存在 /usr/local/bin/docker-compose,这将使该软件作为 docker-compose 在全局范围内可访问:

sudo curl -L "https://github.com/docker/compose/releases/download/1.29.2/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose

接下来,设置正确的权限,以便 docker-compose 命令可执行:

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

要验证安装是否成功,可以运行:

docker-compose --version

您将看到类似于以下内容的输出:

docker-compose version 1.29.2, build 5becea4c

Docker Compose 现在已成功安装在您的系统上。在下一节中,您将看到如何设置 docker-compose.yml 文件,并使用该工具启动容器化环境。

步骤 2 — 设置 docker-compose.yml 文件

为了演示如何设置 docker-compose.yml 文件并使用 Docker Compose,您将使用 Docker Hub 上的官方 Nginx 镜像,这是公共 Docker 注册表。这个容器化环境将提供一个单一的静态 HTML 文件。

首先,在您的主目录中创建一个新目录,然后进入该目录:

mkdir ~/compose-demo
cd ~/compose-demo

在此目录中,设置一个应用程序文件夹,作为您的 Nginx 环境的文档根目录:

mkdir app

使用您喜欢的文本编辑器,在 app 文件夹中创建一个新的 index.html 文件:

nano app/index.html

将以下内容放入此文件中:

<!doctype html>
<html lang="en">
<head>
    <meta charset="utf-8">
    <title>Docker Compose Demo</title>
    <link rel="stylesheet" href="https://cdn.jsdelivr.net/gh/kognise/water.css@latest/dist/dark.min.css">
</head>
<body>
    <h1>This is a Docker Compose Demo Page.</h1>
    <p>This content is being served by an Nginx container.</p>
</body>
</html>

完成后保存并关闭文件。如果您使用的是 nano,可以通过输入 CTRL+X,然后输入 YENTER 来确认。

接下来,创建 docker-compose.yml 文件:

nano docker-compose.yml

docker-compose.yml 文件中插入以下内容:

version: '3.7'
services:
  web:
    image: nginx:alpine
    ports:
      - "8000:80"
    volumes:
      - ./app:/usr/share/nginx/html

docker-compose.yml 文件通常以 version 定义开始。这将告诉 Docker Compose 您正在使用哪个配置版本。

然后是 services 块,您在其中设置了此环境的服务。在您的情况下,有一个名为 web 的单个服务。此服务使用 nginx:alpine 镜像,并使用 ports 指令设置端口重定向。主机(运行 Docker Compose 的系统)上端口 8000 的所有请求将被重定向到 web 容器上的端口 80,其中 Nginx 将运行。

volumes 指令将在主机和容器之间创建一个共享卷。这将使用容器内的 /usr/share/nginx/html 目录共享本地的 app 文件夹,并且该卷将覆盖 Nginx 的默认文档根目录。

保存并关闭文件。

您已经设置了一个演示页面和一个 docker-compose.yml 文件,以创建一个容器化的 Web 服务器环境来提供它。在下一步中,您将使用 Docker Compose 启动此环境。

步骤 3 — 运行 Docker Compose

有了 docker-compose.yml 文件,现在可以执行 Docker Compose 来启动你的环境。以下命令将下载必要的 Docker 镜像,为 web 服务创建一个容器,并在后台模式下运行容器化环境:

docker-compose up -d

Docker Compose 首先会在本地系统中查找定义的镜像,如果找不到镜像,它将从 Docker Hub 下载镜像。你会看到如下输出:

Creating network "compose-demo_default" with the default driver
Pulling web (nginx:alpine)...
alpine: Pulling from library/nginx
cbdbe7a5bc2a: Pull complete
10c113fb0c77: Pull complete
9ba64393807b: Pull complete
c829a9c40ab2: Pull complete
61d685417b2f: Pull complete
Digest: sha256:57254039c6313fe8c53f1acbf15657ec9616a813397b74b063e32443427c5502
Status: Downloaded newer image for nginx:alpine
Creating compose-demo_web_1 ... done

你的环境现在在后台运行。要验证容器是否活动,可以运行:

docker-compose ps

此命令将显示有关正在运行的容器及其状态的信息,以及当前设置的任何端口重定向:

Name                     Command               State          Ports        
----------------------------------------------------------------------------------
compose-demo_web_1   /docker-entrypoint.sh ngin ...   Up      0.0.0.0:8000->80/tcp

现在,你可以通过将浏览器指向 localhost:8000(如果在本地机器上运行此演示)或 your_server_domain_or_IP:8000(如果在远程服务器上运行此演示)来访问演示应用程序。

你将看到如下页面:

!Docker Compose Demo Page

你在 docker-compose.yml 文件中设置的共享卷可使 app 文件夹中的文件与容器的文档根目录保持同步。如果对 index.html 文件进行任何更改,容器将自动捕获这些更改,并在重新加载页面时反映在你的浏览器上。

在下一步中,你将了解如何使用 Docker Compose 命令来管理容器化环境。

步骤 4 — 熟悉 Docker Compose 命令

你已经了解了如何设置 docker-compose.yml 文件,并使用 docker-compose up 启动你的环境。现在,你将了解如何使用 Docker Compose 命令来管理和与容器化环境交互。

要检查 Nginx 容器产生的日志,可以使用 logs 命令:

docker-compose logs

你将看到类似于以下的输出:

Attaching to compose-demo_web_1
web_1  | /docker-entrypoint.sh: /docker-entrypoint.d/ is not empty, will attempt to perform configuration
web_1  | /docker-entrypoint.sh: Looking for shell scripts in /docker-entrypoint.d/
web_1  | /docker-entrypoint.sh: Launching /docker-entrypoint.d/10-listen-on-ipv6-by-default.sh
web_1  | 10-listen-on-ipv6-by-default.sh: Getting the checksum of /etc/nginx/conf.d/default.conf
web_1  | 10-listen-on-ipv6-by-default.sh: Enabled listen on IPv6 in /etc/nginx/conf.d/default.conf
web_1  | /docker-entrypoint.sh: Launching /docker-entrypoint.d/20-envsubst-on-templates.sh
web_1  | /docker-entrypoint.sh: Configuration complete; ready for start up
web_1  | 172.22.0.1 - - [02/Jun/2020:10:47:13 +0000] "GET / HTTP/1.1" 200 353 "-" "Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/83.0.4103.61 Safari/537.36" "-"

如果要暂停环境执行而不更改容器的当前状态,可以使用:

docker-compose pause
Pausing compose-demo_web_1 ... done

要在发出暂停后恢复执行:

docker-compose unpause
Unpausing compose-demo_web_1 ... done

stop 命令将终止容器执行,但不会销毁与你的容器相关的任何数据:

docker-compose stop
Stopping compose-demo_web_1 ... done

如果要删除与此容器化环境相关的容器、网络和卷,可以使用 down 命令:

docker-compose down
Removing compose-demo_web_1 ... done
Removing network compose-demo_default

请注意,这不会从 Docker Compose 用于启动你的环境的基本镜像中删除基本镜像(在你的情况下是 nginx:alpine)。这样,每当你使用 docker-compose up 再次启动你的环境时,过程会快得多,因为镜像已经在你的系统上。

如果你想从系统中删除基本镜像,可以使用:

docker image rm nginx:alpine
Untagged: nginx:alpine
Untagged: nginx@sha256:b89a6ccbda39576ad23fd079978c967cecc6b170db6e7ff8a769bf2259a71912
Deleted: sha256:7d0cdcc60a96a5124763fddf5d534d058ad7d0d8d4c3b8be2aefedf4267d0270
Deleted: sha256:05a0eaca15d731e0029a7604ef54f0dda3b736d4e987e6ac87b91ac7aac03ab1
Deleted: sha256:c6bbc4bdac396583641cb44cd35126b2c195be8fe1ac5e6c577c14752bbe9157
Deleted: sha256:35789b1e1a362b0da8392ca7d5759ef08b9a6b7141cc1521570f984dc7905eb6
Deleted: sha256:a3efaa65ec344c882fe5d543a392a54c4ceacd1efd91662d06964211b1be4c08
Deleted: sha256:3e207b409db364b595ba862cdc12be96dcdad8e36c59a03b7b3b61c946a5741a

结论

在本指南中,您已经学会了如何安装 Docker Compose 并基于 Nginx web 服务器镜像设置容器化环境。您还学会了如何使用 Compose 命令管理此环境。

要获取所有可用的 docker-compose 命令的完整参考,请查阅官方文档。

如果您对 Docker Compose 的更多用法感兴趣,请查看《如何使用 Docker Compose 安装 WordPress》以及《如何使用 Nginx、Let’s Encrypt 和 Docker Compose 保护容器化的 Node.js 应用程序》。


目录
相关文章
|
4天前
|
Ubuntu Linux 测试技术
Linux系统之Ubuntu安装cockpit管理工具
【10月更文挑战第13天】Linux系统之Ubuntu安装cockpit管理工具
25 4
Linux系统之Ubuntu安装cockpit管理工具
|
5天前
|
关系型数据库 MySQL Linux
Docker安装Mysql5.7,解决无法访问DockerHub问题
当 Docker Hub 无法访问时,可以通过配置国内镜像加速来解决应用安装失败和镜像拉取超时的问题。本文介绍了如何在 CentOS 上一键配置国内镜像加速,并成功拉取 MySQL 5.7 镜像。
50 2
Docker安装Mysql5.7,解决无法访问DockerHub问题
|
9天前
|
Ubuntu 应用服务中间件 nginx
Ubuntu安装笔记(三):ffmpeg(3.2.16)源码编译opencv(3.4.0)
本文是关于Ubuntu系统中使用ffmpeg 3.2.16源码编译OpenCV 3.4.0的安装笔记,包括安装ffmpeg、编译OpenCV、卸载OpenCV以及常见报错处理。
42 2
Ubuntu安装笔记(三):ffmpeg(3.2.16)源码编译opencv(3.4.0)
|
9天前
|
Ubuntu Linux C语言
Ubuntu安装笔记(二):ubuntu18.04编译安装opencv 3.4.0 opencv_contrib3.4.0
本文介绍了在Ubuntu 18.04系统上编译安装OpenCV 3.4.0及其扩展包opencv_contrib 3.4.0的详细步骤,包括下载源码、安装依赖、配置CMake和编译安装,以及常见问题的解决方法。
14 1
Ubuntu安装笔记(二):ubuntu18.04编译安装opencv 3.4.0 opencv_contrib3.4.0
|
5天前
|
Kubernetes Ubuntu Docker
从0开始搞K8S:使用Ubuntu进行安装(环境安装)
通过上述步骤,你已经在Ubuntu上成功搭建了一个基本的Kubernetes单节点集群。这只是开始,Kubernetes的世界广阔且深邃,接下来你可以尝试部署应用、了解Kubernetes的高级概念如Services、Deployments、Ingress等,以及探索如何利用Helm等工具进行应用管理,逐步提升你的Kubernetes技能树。记住,实践是最好的老师,不断实验与学习,你将逐渐掌握这一强大的容器编排技术。
17 1
|
5天前
|
数据可视化 数据挖掘 Docker
Docker Desktop 安装 ClickHouse 超级简单教程
Docker Desktop 安装 ClickHouse 超级简单教程
18 1
|
6天前
|
Ubuntu Linux 网络安全
Docker&Docker Compose安装(离线+在线)
Docker&Docker Compose安装(离线+在线)
64 1
|
8天前
|
NoSQL Linux Redis
Docker学习二(Centos):Docker安装并运行redis(成功运行)
这篇文章介绍了在CentOS系统上使用Docker安装并运行Redis数据库的详细步骤,包括拉取Redis镜像、创建挂载目录、下载配置文件、修改配置以及使用Docker命令运行Redis容器,并检查运行状态和使用Navicat连接Redis。
63 3
|
9天前
|
Ubuntu Linux
软件安装(五):Ubuntu 18.04安装Teamviewer 看一遍就会
这篇文章介绍了在Ubuntu 18.04系统上通过图形界面和命令行两种方法安装TeamViewer远程控制软件的步骤。
16 2
|
10天前
|
存储 Kubernetes 调度
掌握 Docker Compose
【10月更文挑战第6天】
14 1