Docker Compose:简化多容器应用部署

序言

在当今的软件开发中,容器化技术的使用已经很普遍了。而 Docker 作为其中最流行的容器化平台之一,为开发者提供了方便、快捷、一致的开发和部署环境。但是,当我们的应用开始变得更加复杂,涉及到多个容器时,手动管理这些容器之间的依赖关系和部署过程将会变得非常繁琐。这时候,Docker Compose 就能帮助我们解决这些问题。

一、什么是 Docker Compose

Docker Compose 是 Docker 官方推出的一个工具,用于定义和运行多容器 Docker 应用。通过使用 Docker Compose,开发者可以通过一个简单的 YAML 文件来定义多个容器之间的关系、配置信息、网络设置等,从而实现一键式的应用部署。

二、安装 Docker Compose

Docker Compose 需要额外安装,安装的方式有两种:

  1. 插件方式安装
  2. standalone 方式安装

2.1 插件安装 Docker Compose

  1. 执行以下命令安装 Docker Compose 插件

    bash 复制代码
    # Ubuntu 命令
    sudo apt-get install docker-compose-plugin
    
    # CentOS 命令
    yum install docker-compose-plugin
  2. 执行以下命令验证安装

    bash 复制代码
    docker compose version

    安装结果:

2.2 standalone 方式安装

  1. 执行以下命令安装 Docker Compose 独立版本

    bash 复制代码
    # 以下命令 linux 通用
    curl -SL https://github.com/docker/compose/releases/download/v2.27.0/docker-compose-linux-x86_64 -o /usr/local/bin/docker-compose
    
    # 添加执行权限
    sudo chmod +x /usr/local/bin/docker-compose
  2. 执行以下命令验证安装

    bash 复制代码
    docker-compose --version

    安装结果:

三、使用 Docker Compose

Docker Compose 的使用一般分为以下 3 步:

  1. 编写 Docker Compose 文件 :创建一个名为 docker-compose.yml 的 YAML 格式文件,并在其中定义各个服务的配置信息,包括镜像、端口映射、环境变量、依赖关系等。
  2. 启动应用 :在 Docker Compose 文件所在目录下,运行命令 docker-compose up,Docker Compose 将会根据配置文件启动所有的容器。
  3. 停止应用 :运行命令 docker-compose down,Docker Compose 将会停止并移除所有的容器。

四、使用案例

场景假设:我们需要部署两个容器,分别是 Kibana 和 Elasticsearch。其中,Kibana 依赖 Elasticsearch(注:我们采用 standalone 方式部署的 Docker Compose)

  1. 编写 docker-compose.yml文件

    yaml 复制代码
    # 指定 Docker Compose 文件的版本
    version: '3.7'
    
    # 定义服务
    services:
      # Elasticsearch 服务
      es:
        # 使用 Elasticsearch 镜像
        image: docker.elastic.co/elasticsearch/elasticsearch:7.15.1
        # 指定容器名称
        container_name: es
        # 设置环境变量
        environment:
          - ES_JAVA_OPTS=-Xms512m -Xmx512m
          - discovery.type=single-node
        # 挂载卷
        volumes:
          - es-data:/usr/share/elasticsearch/data
          - es-logs:/usr/share/elasticsearch/logs
          - es-plugins:/usr/share/elasticsearch/plugins
        # 授予特权权限
        privileged: true
        # 指定网络
        networks:
          - es-net
        # 端口映射
        ports:
          - "9200:9200"
          - "9300:9300"
    
      # Kibana 服务
      kibana:
        # 使用 Kibana 镜像
        image: docker.elastic.co/kibana/kibana:7.15.1
        # 指定容器名称
        container_name: kibana
        # 设置环境变量
        environment:
          - ELASTICSEARCH_HOSTS=http://es:9200
        # 指定网络
        networks:
          - es-net
        # 端口映射
        ports:
          - "5601:5601"
        # 依赖关系,确保 Elasticsearch 服务先于 Kibana 服务启动
        depends_on:
          - es
    
    # 定义网络
    networks:
      # 定义名为 es-net 的网络,使用 bridge 驱动
      es-net:
        driver: bridge
    
    # 定义卷
    volumes:
      # 定义名为 es-data 的卷
      es-data:
      # 定义名为 es-logs 的卷
      es-logs:
      # 定义名为 es-plugins 的卷
      es-plugins:
  2. docker-compose.yml文件所在目录执行命令启动应用

    bash 复制代码
    # 根据 docker-compose.yml 文件启动服务, 前台启动
    docker-compose up
    
    # 后台启动
    docker-compose up -d

    正常启动日志:

    打开浏览器输入网址 localhost:5601 查看 Kibana 容器启动情况

  3. 停止应用

    bash 复制代码
    # 停止后台运行的应用
    docker-compose down

五、FAQ

Docker Compose 如果以插件方式安装,那么执行命令是 docker compose [选项] 的格式,若是以 standalone 方式安装,那么执行命令的格式是 docker-compose [选项]

推荐阅读

  1. RabbitMQ(Docker 单机部署)
  2. 深入理解 Java 并发:AbstractQueuedSynchronizer 源码分析
  3. 深入了解 Arthas:Java 应用程序诊断利器
  4. 基于 AI 的数据库助手-Chat2DB
  5. EasyExcel 处理 Excel
相关推荐
Harvy_没救了18 分钟前
【网络运维】 WordPress 部署复盘
运维·网络
weixin_4022784528 分钟前
VS code 本地推送github添加SSH设置
运维·git·ssh
fish_xk31 分钟前
Linux的权限
linux·运维·服务器
嵌入式×边缘AI:打怪升级日志2 小时前
Linux 驱动与应用开发核心自测题库(面试官问答完整版)
linux·运维·php
eastyuxiao3 小时前
企业 OpenClaw 文档自动化落地项目 - 思维导图范围拆解
运维·自动化
Sirens.3 小时前
Umami:从Cloud迁移到服务器
运维·服务器
zhangfeng11334 小时前
CI/CD 是软件开发中的两个核心实践,合起来指代一套自动化的软件交付流程
运维·ci/cd·自动化
嵌入式×边缘AI:打怪升级日志4 小时前
Tina SDK Linux Kernel 基本使用(实战篇:为7寸RGB LCD触摸屏添加驱动支持).md
linux·运维·服务器
十 一 丶4 小时前
如何在客户端实现ssh的免密登录?
运维·rust·ssh
G.晴天4 小时前
Linux常用命令练习流程
java·linux·运维·服务器·tomcat