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

server/2024/12/31 1:13:17/

序言

在当今的软件开发中,容器化技术的使用已经很普遍了。而 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 插件

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

    docker compose version
    

    安装结果:

    image.png

2.2 standalone 方式安装

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

    # 以下命令 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. 执行以下命令验证安装

    docker-compose --version
    

    安装结果:

    image.png

三、使用 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文件

    # 指定 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文件所在目录执行命令启动应用

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

    正常启动日志:

    image.png

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

    image.png

  3. 停止应用

    # 停止后台运行的应用
    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

http://www.ppmy.cn/server/39396.html

相关文章

linux学习笔记——硬盘原理以及linux中的sector与block

在计算机硬盘中,最小的存储单位叫做扇区sector,0.5kb,多个连续扇区组合在一起形成了块block,最小的块包含8个扇区,4kb 我们可以在linux中印证 创建一个新的文件2.txt,查看文件大小为0k 在文件中添加字符后…

适合年轻人的恋爱交友脱单软件有哪些?中国十大社交软件排行榜分享

交友始祖:Tinder 一直很受欢迎,可以向上扫给 super like (每日有一次免费机会)。如果双方互相 like,代表配对成功,就可以开始聊天。另外,每日有 10 个 top picks 供选择,你可以免费选一位 主力编外&#xf…

RustGUI学习(iced)之小部件(八):如何使用svg部件显示矢量图形?

前言 本专栏是学习Rust的GUI库iced的合集,将介绍iced涉及的各个小部件分别介绍,最后会汇总为一个总的程序。 iced是RustGUI中比较强大的一个,目前处于发展中(即版本可能会改变),本专栏基于版本0.12.1. 概述 这是本专栏的第八篇,主要讲述svg矢量图形部件的使用,会结合实…

7-Zip的介绍

7-Zip是一个开源的文件压缩和解压缩软件,它能够处理多种压缩格式,包括其自有的7z格式,以及常见的ZIP、RAR、TAR等格式。以下是一些关于7-Zip的详细介绍: 1. **开源免费**:7-Zip是一个完全开源的软件,可以免…

【ROMA核心特性数据、服务、消息、设备集成及统一运维】

1、数据集成 FDI旨在解决多种数据源的快速灵活集成能力,您可以在任意时间、任意地点、任意系统之间实现实时数据订阅和定时增量数据迁移。 (1)数据集成任务的生命周期管理 (2)FDI支持修改数据集成任务的信息、查看数…

开发环境待

一 web开发环境搭建 1 web开发环境概述 所谓web开发,指的就是从网页中向后端程序发送请求.与后端程序进行交互. 流程图: 1,Web服务器是指驻留于因特网上某种类型计算机的程序. 2, 可以向浏览器等Web客户端提供文档,也可以放置网站文件,让全世界 浏览…

PXE高效批量装机

一、PXE的概述 PXE是由Inter 公司开发的网络引导技术,工作在Client / Server 模式。允许客户机通过网络从远程服务器下载引导镜像,并加载安装文件或者整个操作系统。 1.1PXE优点 规模化:同时装配多台服务器 自动化:安装系统&am…

分布式存储CephFS最佳实践

文章来源于知乎文章: 分布式存储CephFS最佳实践 背景 近日,一朋友说他们企业内部想落地CephFS,让我帮忙写一份能落地的CephFS最佳实践。然后就顺便把文章整理到了这里。因能力水平以及认知有限,如有错漏烦请指正。 简介 CephF…