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 插件

    # 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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/609621.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

kafka(七)——消息偏移(消费者)

概念 消费者消费完消息后,向_consumer_offset主题发送消息,用来保存每个分区的偏移量。 流程说明 consumer发送JoinGroup请求;coordinator选出一个consumer作为leader,并将topics发送给leader消费者;leader consumer…

4. Python的深拷贝、浅拷贝

文章目录 0、先说结论1、浅拷贝修改元素值2、深拷贝修改元素值学习链接 0、先说结论 无论深拷贝还是浅拷贝都会为新对象分配一块新的内存,因此新老对象id不相同。 对于浅拷贝,新老对象内部的可变and不可变元素id都是相同的(在没修改元素值之前)。 对于深…

springboot -多数据源管理方案

多数据源的配置有多种方式 方式一 、依赖dataSource的配置 1.建立多数据源配置 spring:# 数据源配置datasource:pdm:driver-class-name: oracle.jdbc.driver.OracleDriverjdbc-url: jdbc:oracle:thin:10.216.xxx.xxx:3000:orclusername: cfpdmpassword: capecapp:driver-cla…

移动安全测试框架-MobSF window环境配置

一. 介绍: MOBSF(Mobile Security Framework)是一个开源的移动安全渗透测试框架,用于评估移动应用程序的安全性。它提供了一组功能强大的工具和技术,帮助安全专业人员和开发人员发现和修复移动应用程序中的安全漏洞。 …

React 第二十六章 Hook useCallback

useCallback 是 React 提供的一个 Hook 函数,用于优化性能。它的作用是返回一个记忆化的函数,当依赖发生变化时,才会重新创建并返回新的函数。 在 React 中,当一个组件重新渲染时,所有的函数都会被重新创建。这可能会…

【npm】解决npm包突然消失MODULE_NOT_FOUND

今天折腾新特性时需要升级nodejs,安装新版后npm离奇消失了。C:\Users\**用户名\AppData\Roaming\npm\node_modules下只有cnpm,没有npm的目录。重装nodejs也不好使。 机智如我,试了下cnpm -v是正常的,而且能看到nodejs,…

CSP-j 2022csp-j完善程序易错题

易错题 答案23: 对 解析23: 函数 g 就是把函数 f 改成递推的形式 答案24: 对 解析23: 无。 答案25: C 解析25: m n ( m - 1 ) * ( 1 2 3 4 ... n ) O(mn^2) 答案26: C 解析26&#x…

跨境电商行业蓬勃发展,武汉星起航引领卖家孵化新潮流

近年来,我国跨境电商行业在政府的大力扶持下呈现出强劲的发展势头。随着国内制造业结构的加速调整与居民消费需求升级态势的持续凸显,跨境出口规模占比稳步提升,跨境进口规模同样不断扩大,行业市场规模持续增长。在这一背景下&…

vue3+ant design实现表格数据导出Excel

提示:实现表格数据导出Excel 文章目录 前言 一、安装ant design? 二、引用ant design 1.搭建框架 2.获取表格数据 三、封装导出表格的代码 四、导出 1.获取导出地址 2.在下载导出事件中添加导出代码 五、全部代码 前言 今天终于有时间来更新文章了,最近公司项目比较紧…

【ArcGIS Pro微课1000例】0058:玩转NetCDF多维数据集

一、NetCDF介绍 NetCDF(network Common Data Form)网络通用数据格式是由美国大学大气研究协会(University Corporation for Atmospheric Research,UCAR)的Unidata项目科学家针对科学数据的特点开发的,是一种面向数组型并适于网络共享的数据的描述和编码标准。NetCDF广泛应…

pgsql查看指定模式的存储过程

pgsql查看指定模式的存储过程 在 PostgreSQL 中,如果你想要查看指定模式的存储过程(也称为函数),你可以使用 \df 或 \df 命令在 psql 命令行工具中,或者使用 SQL 查询来从 pg_catalog 系统模式中查询。 \df命令行查询…

吴恩达2022机器学习专项课程C2(高级学习算法)W1(神经网络):Lab01 神经元和层

目录 导入Tensorflow的库无激活函数 vs 有激活函数?1.无激活函数2.有激活函数 无激活函数的神经元-回归/线性模型1.创建训练集散点图2.创建层3.层输入4.获取层参数5.层参数的形状6.手动设置层的参数7.层计算vs线性回归模型计算 有激活函数sigmoid的神经元1.创建训练…

武汉星起航深耕亚马逊跨境电商,引领中国卖家开拓全球市场新篇章

在全球经济深度融合的当下,跨境电商已成为连接中国与世界市场的重要桥梁。作为跨境电商领域的佼佼者,武汉星起航电子商务有限公司凭借对亚马逊平台的深入了解和丰富经验,成功引领了中国卖家开拓全球市场的新篇章。 亚马逊,这家起…

计算机发展史故事【7】

二战建奇勋 布雷契莱庄园当然不信德寇的邪说,他们把大约200 名精干人员集中在“3号棚”,四班轮换,24 小时值守,专门对付德国的“斯芬克司之谜”。图林则带着副手、象棋冠军亚历山大,领导着“8 号棚”,进行…

安卓开发--新建工程,新建虚拟手机,按键事件响应

安卓开发--新建工程,新建虚拟手机,按键事件响应 1.前言2.运行一个工程2.1布局一个Button2.2 button一般点击事件2.2 button属性点击事件2.2 button推荐点击事件 本篇博客介绍安卓开发的入门工程,通过使用按钮Buton来了解一个工程的运作机制。…

【论文合集1】- 存内计算加速机器学习

本章节论文合集,存内计算已经成为继冯.诺伊曼传统架构后,对机器学习推理加速的有效解决方案,四篇论文从存内计算用于机器学习,模拟存内计算,对CNN/Transformer架构加速角度阐述存内计算。 【1】WWW: What, When, Where…

Web实时通信的学习之旅:WebSocket入门指南及示例演示

文章目录 WebSocket的特点1、工作原理2、特点3、WebSocket 协议介绍4、安全性 WebSocket的使用一、服务端1、创建实例:创建一个webScoket实例对象1.1、WebSocket.Server(options[,callback])方法中options对象所支持的参数1.2、同样也有一个加密的 wss:/…

2024第九届数维杯数学建模论文模板(内附LaTeX+Word)

一年一度的2024年第九届数维杯国赛报名进行中!相信很多同学们已经摩拳擦掌蓄势待发了! 经历三天比赛,最后提交的论文就是最终答卷,那么一篇数模论文,包括哪些内容呢? 一篇完整的数模论文,包括…

【初阶数据结构】单链表经典OJ题

目录标题 原题展现题目解析代码展现1.创建新节点2.拷贝random指针3.将新节点尾插 原题展现 该题是力扣上的第138题,题目链接如下:随机链表的复制。 题目解析 我们发现这个链表和一般的链表存在着一点点区别,那就是每个节点多了一个random指…

遥控挖掘机之ESP8266调试心得(1)

ESP8266调试心得 1. 前言2.遇到的问题2.1 ESP8266模块建立TCP连接时候报错2.2 指令异常问题 3. 更新ESP8266固件3. ESP8266的部分AT指令3. 连接步骤3.1 模块与电脑连接3.2.1 电脑上的设置3.2.2 ESP8266模块作为客户机(TCP Cilent)的设置步骤 3.2 模块与模…