在 Debian 10 Linux 上安装和使用 Docker Compose

本教程介绍了如何在 Debian 10 Buster 上安装最新版本的 Docker Compose 。我们还将探讨基本的 Docker Compose 概念和命令。

Docker 是一个容器化平台,可让您快速构建,测试和部署应用程序,作为可在几乎任何地方运行的可移植,自给自足的容器。

Docker Compose 是一个工具,可用于定义和编排多容器 Docker 应用程序。它使用 YAML 文件来配置应用程序的容器,网络和卷。

Compose 可以用于各种场景,单个主机应用程序部署,自动化测试和本地开发是 Docker Compose 最受欢迎的用例。

先决条件

在继续之前,请确保您满足以下先决条件:

在 Debian 10 上安装 Docker Compose

Docker Compose 安装软件包可在 Debian 10 官方存储库中找到,但不一定总是最新版本。推荐的方法是从 Docker 的 GitHub 存储库安装 Docker Compose 。

在撰写本文时,最新的 Docker Compose 稳定版本是 1.23.1 。在下载 Compose 二进制文件之前,请访问 GitHub 上的 Compose 存储库发行页面,并检查是否有新版本可下载。

使用以下步骤在 Debian 10 上安装最新版本的 Docker Compose :

  1. 使用 wgetcurl 将 Docker Compose 二进制文件下载到/usr/local/bin 目录中 :

    sudo curl -L " https://github.com/docker/compose/releases/download/1.23.1/docker-compose-$(uname -s)-$(uname -m) "  -o /usr/local/bin/docker-compose 
    
  2. 使用 chmod 使撰写二进制可执行文件:

    sudo chmod +x /usr/local/bin/docker-compose
    
  3. 要验证安装,请使用以下命令打印出 Compose 版本:

    docker-compose --version
    

    输出将如下所示:

    docker-compose version 1.23.1, build b02f1306

Docker Compose 入门

在本节中,我们将展示如何使用 Docker Compose 设置本地 WordPress 开发环境。

为项目创建一个目录并导航到其中

mkdir wordpress_app && cd wordpress_app

打开文本编辑器,然后创建一个文件,名为的docker-compose.yml

nano docker-compose.yml

粘贴以下内容:

version: '3.7'

services:
  db:
    image: mysql:8.0
    command: --default-authentication-plugin=mysql_native_password
    restart: always
    volumes:
      - db_data:/var/lib/mysql
    environment:
      MYSQL_ROOT_PASSWORD: password
      MYSQL_DATABASE: wordpress

  wordpress:
    image: wordpress
    restart: always
    volumes:
      - ./wp_data:/var/www/html
    ports:
      - "8080:80"
    environment:
      WORDPRESS_DB_HOST: db:3306
      WORDPRESS_DB_NAME: wordpress
      WORDPRESS_DB_USER: root
      WORDPRESS_DB_PASSWORD: password
    depends_on:
       - db

volumes:
    db_data:
    wp_data:

让我们逐行解释代码

第一行指定 Compose 文件的版本。有多种不同版本的 Compose 文件格式,支持特定的 Docker 版本。

接下来,我们定义两个服务: dbwordpress 。运行 Docker Compose 时,每个服务都会创建一个单独的容器。

db 服务

  • 镜像被设置为 mysql:8.0 镜像。如果不存在该映像,则 Compose 将从 Docker Hub 公共存储库中提取该映像。以 command 开头的行将覆盖默认命令。
  • restart: always 策略指示 Compose 如果发生故障,请重新启动容器。
  • 容器将使用命名卷 db_data 来持久化数据库。
  • 定义 mysql:8.0 镜像的环境变量。

wordpress 服务:

  • 使用 wordpress 镜像。
  • 将主机上的目录挂载到 /var/lib/mysql 容器内部 wp_data
  • 将容器上的裸露 8080 端口转发到主机上的 80 端口。
  • 定义 wordpress 镜像的环境变量
  • depends_on 指令定义了两个服务之间的依赖关系。在此示例中, db 将在 wordpress 之前启动。

在项目目录中,通过运行以下命令来启动 WordPress 堆栈:

docker-compose up

输出应如下所示:

...
] /usr/sbin/mysqld: ready for connections. Version: '8.0.18'  socket: '/var/run/mysqld/mysqld.sock'  port: 3306  MySQL Community Server - GPL.
db_1_99946702ac7e | 2019-12-15T21:37:29.109255Z 0 [System] [MY-011323] [Server] X Plugin ready for connections. Socket: '/var/run/mysqld/mysqlx.sock' bind-address: '::' port: 33060
...

Docker Compose 将提取镜像,启动容器,并在您的项目目录中创建目录 wp_data

在浏览器中输入 http://0.0.0.0:8080/ ,您将看到标准的 WordPress 安装屏幕。

至此, WordPress 应用程序已启动并运行,您可以开始使用它了。

要停止撰写,请按 CTRL+C

您还可以使用以下 -d 选项以分离模式启动 Compose  :

docker-compose up -d

要查看正在运行的 Docker 容器,请使用以下命令:

docker-compose ps
                 Name                               Command               State          Ports        
------------------------------------------------------------------------------------------------------
wordpress_app_db_1_99946702ac7e          docker-entrypoint.sh --def ...   Up      3306/tcp, 33060/tcp 
wordpress_app_wordpress_1_a428d8408817   docker-entrypoint.sh apach ...   Up      0.0.0.0:8080->80/tcp 

要在Compose以分离模式运行时停止服务,请使用:

docker-compose stop

如果要完全删除容器,请使用以下down选项:

docker-compose down

通过 --volumes 选项还会删除数据量:

docker-compose down --volumes

卸载 Docker Compose

如果需要卸载 Docker Compose,只需输入以下内容即可删除二进制文件:

sudo rm /usr/local/bin/docker-compose

结论

要在 Debian 10 上安装 Docker Compose,只需将二进制文件下载到系统路径中的目录中并使其具有可执行权限即可。