Docker进阶:Docker-compose 实现服务弹性伸缩

Docker进阶:Docker-compose 实现服务弹性伸缩

  • 一、Docker Compose基础概念
    • 1.1 Docker Compose简介
    • 1.2 Docker Compose文件结构
  • 二、弹性伸缩的原理和实现步骤
    • 2.1 弹性伸缩原理
    • 2.2 实现步骤
  • 三、技术实践案例
    • 3.1 场景描述
    • 3.2 配置Docker Compose文件
    • 3.3 使用 docker-compose create 创建整个服务配置中定义的所有容器实例
    • 3.4 docker-compose常用命令
    • 3.5 修改Docker Compose文件用于创建多个服务的实例数量


💖The Begin💖点点关注,收藏不迷路💖

在这里插入图片描述

前提你已经安装了Docker Compose

在这里插入图片描述

一、Docker Compose基础概念

1.1 Docker Compose简介

Docker Compose是一个用于定义和运行多个Docker容器的工具,它通过一个单独的文件来配置应用的服务,并使用命令行工具来启动、停止和重新创建这些服务。

通过Docker Compose,我们可以方便地定义一个应用的各个组件,并且能够通过简单的命令来进行管理。

1.2 Docker Compose文件结构

Docker Compose文件通常以docker-compose.yml为文件名,其中包含了应用的服务定义、网络设置、数据卷挂载等信息。

该文件采用YAML格式,通过缩进来表示层级关系,易于阅读和编写。

二、弹性伸缩的原理和实现步骤

2.1 弹性伸缩原理

弹性伸缩是指根据系统负载情况,自动增加或减少资源以满足当前需求的能力。在Docker Compose中,我们可以通过监控应用的负载情况,动态地调整应用服务的实例数量,从而实现弹性伸缩。

2.2 实现步骤

实现弹性伸缩的关键在于监控和自动化。我们可以通过监控应用的CPU、内存、网络等指标,结合自动化脚本来实现弹性伸缩。具体步骤包括:

1、监控应用的负载情况,获取关键指标;
2、编写自动化脚本,根据监控指标来动态调整服务实例数量;
3、配置Docker Compose文件,定义应用服务的最小和最大实例数量。

三、技术实践案例

3.1 场景描述

假设我们有一个Web应用,由Nginx作为反向代理,后端服务使用Node.js编写的API服务。我们希望在高负载时能够自动增加API服务的实例数量,以应对突发流量。

3.2 配置Docker Compose文件

Docker Compose官网文档:https://docs.docker.com/compose/compose-file/compose-file-v2/

以下是一个简单的docker-compose.yml配置示例,用于实现Nginx反向代理的弹性伸缩:

1、vim docker-compose.yml,编写如下内容:

version: '3.7'

services:
  web-nginx:
    image: nginx:latest
    restart: "always"
    environment:
      APP_ENV: development
    ports:
      - "80:80"
    networks:
      - my_network
    volumes:
      -  /etc/nginx/nginx.conf:/etc/nginx/nginx.conf
      -  /usr/local/nginx/html:/usr/local/nginx/html

networks:
  my_network:
    driver: bridge
    ipam:
      driver: default
      config:
        - subnet: 172.16.238.0/24
          gateway: 172.16.238.1

2、docker-compose config,验证 docker-compose.yml 文件

docker-compose config

这个命令会检查并输出有效的 Docker Compose 配置。

在这里插入图片描述

3.3 使用 docker-compose create 创建整个服务配置中定义的所有容器实例

docker-compose create    web-nginx

在这里插入图片描述

后台模式下启动docker-compose服务,启动web-nginx 的服务容器实例。

## -d 后台模式
docker-compose up -d  web-nginx  

在这里插入图片描述

3、查看使用docker-compose启动的所有服务的状态

docker-compose ps

这将显示docker-compose中定义的所有服务的状态信息,包括容器ID、名称、状态等。

在这里插入图片描述
而要查看所有正在运行的Docker容器,不管是通过docker-compose启动的还是其他方式启动的,可以使用以下命令:

## 当前运行的
docker ps

# #所有、包括运行过的
docker ps -qa

这将列出所有正在运行的Docker容器,包括容器ID、名称、镜像、端口映射等信息。

3.4 docker-compose常用命令

若修改了 docker-compose.yml 文件,使用 docker-compose up -d web-nginx ,再次运行即可。

docker-compose up: 构建并启动所有服务。
docker-compose up -d: 在后台模式下构建并启动所有服务。
docker-compose down: 停止并移除所有服务(并且默认情况下也会删除与这些服务关联的容器、网络和数据卷)。
docker-compose ps: 显示服务状态。
docker-compose logs: 查看服务日志(输出所有)。
docker-compose logs -f <service_name> : 指定服务名称来查看该服务的日志。
docker-compose scale:它用于更改服务的实例数量。
docker-compose restart <service_name>: 重启指定服务。
docker-compose start <service_name>: 启动指定服务。
docker-compose stop <service_name>: 停止指定服务。
docker-compose exec <service_name> <command>: 在指定服务中执行命令。

docker-compose start :  启动所有服务。
docker-compose stop : 停止所有服务。
docker-compose restart : 重启所有服务。
docker-compose pause: 暂停所有服务。
docker-compose unpause: 恢复暂停的所有服务。

3.5 修改Docker Compose文件用于创建多个服务的实例数量

1、把前面创建的 “web-nginx” 的服务的容器实例数量扩展到 3 个。

docker-compose up -d --scale web-nginx=3

报错:(端口被占用)

 Bind for 0.0.0.0:80 failed: port is already allocated

在这里插入图片描述
解决:修改Docker Compose文件(不指定端口、容器名等)

version: '3.7'

services:
  web-nginx:
    image: nginx:latest
    restart: "always"
    environment:
      APP_ENV: development
    ports:
      - 80
    networks:
      - my_network
    volumes:
      -  /etc/nginx/nginx.conf:/etc/nginx/nginx.conf
      -  /usr/local/nginx/html:/usr/local/nginx/html

networks:
  my_network:
    driver: bridge
    ipam:
      driver: default
      config:
        - subnet: 172.16.238.0/24
          gateway: 172.16.238.1

在这里插入图片描述

2、再次执行docker-compose up -d --scale web-nginx=3。

成功启动三个,web-nginx。

在这里插入图片描述
3、查看使用docker-compose启动的所有服务的状态

docker-compose ps

在这里插入图片描述

4、再次执行docker-compose up -d --scale web-nginx=5。增加到5个

在这里插入图片描述

6、再次执行docker-compose up -d --scale web-nginx=3。从5个回退到3个

在这里插入图片描述
在这里插入图片描述


💖The End💖点点关注,收藏不迷路💖

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

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

相关文章

【vue3学习之路(一)】

文章目录 前言一、vue3项目创建1.1环境准备1.1.1 基于 vue-cli 创建&#xff08;脚手架创建&#xff09;1.1.2 基于 vite 创建&#xff08;推荐&#xff09; 二、熟悉流程总结 前言 参考视频&#xff1a;https://www.bilibili.com/video/BV1Za4y1r7KE?p10&spm_id_frompag…

EFcore的实体类配置

1 约定配置 约定大于配置&#xff0c;框架默认了许多实体类配置的规则&#xff0c;在约定规则不满足要求时&#xff0c;可以显示地定义规则 1 数据库表明在不指定的情况下&#xff0c;默认使用的是数据库上下文类【DBContext】中DbSet 的属性名&#xff1b; 2 数据库表列的名字…

Vue3新手教程

Vue3新手教程 一. Vue3简介1. 性能的提升2.源码的升级3. 拥抱TypeScript4. 新的特性 二. 创建Vue3工程1. 基于 vue-cli 创建2. 基于 vite 创建(推荐)3. 一个简单的效果 三. Vue3核心语法1. OptionsAPI 与 CompositionAPI2. 拉开序幕的 setup2.1 setup 概述2.2 setup 的返回值2.…

【计算机考研】 跨考408全年复习规划+资料分享

跨专业备考计算机考研408&#xff0c;确实是一项挑战。在有限的时间内&#xff0c;我们需要合理安排时间&#xff0c;制定有效的学习计划&#xff0c;做到有效地备考。回顾我之前对408的经验&#xff0c;我想分享一些备考计划和方法。 要认清自己的起点。作为跨专业考生&#…

智能计算模拟: DFT+MD+ML 深度融合及科研实践

第一性原理、分子动力学与机器学习三者的交汇融合已在相关研究领域展现强劲的研究热潮。借助第一性原理计算揭示材料内在的量子特性&#xff0c;并结合分子动力学模拟探究材料在实际环境下的动态行为&#xff1b;运用机器学习算法与上述方法结合&#xff0c;开发高性能预测模型…

GaussDB WDR分析之节点篇与点评分析

今天继续介绍GaussDB的WDR报告&#xff0c;我们今天分析一下CN/DN节点的报告。昨天分析集群报告的时候发现集群报告里缺乏一些DBA分析问题所需要的数据&#xff0c;今天我们来看看是否在节点的报告里能够找到它们。GaussDB的节点报告格式都差不多&#xff0c;只不过CN/DN节点的…

力扣hot100:994. 腐烂的橘子(多源BFS)

这是一个典型的多源BFS问题&#xff0c;如果初学数据结构的同学&#xff0c;可能第一次不能想到&#xff0c;但是如果做过一次应该就能运用了。      主要思路大概是初始时&#xff0c;多个点进入队列然后进行BFS。将某一等价集合视作同一个起始点&#xff08;超级源点&…

阿里二面:Java中锁的分类有哪些?你能说全吗?

引言 在多线程并发编程场景中&#xff0c;锁作为一种至关重要的同步工具&#xff0c;承担着协调多个线程对共享资源访问秩序的任务。其核心作用在于确保在特定时间段内&#xff0c;仅有一个线程能够对资源进行访问或修改操作&#xff0c;从而有效地保护数据的完整性和一致性。…

kvm虚拟化

kvm虚拟化 1. 虚拟化介绍 虚拟化是云计算的基础。简单的说&#xff0c;虚拟化使得在一台物理的服务器上可以跑多台虚拟机&#xff0c;虚拟机共享物理机的 CPU、内存、IO 硬件资源&#xff0c;但逻辑上虚拟机之间是相互隔离的。 物理机我们一般称为宿主机&#xff08;Host&…

arm 外部中断

main.c: #include"key_inc.h" //封装延时函数 void delay(int ms) {int i,j;for(i0;i<ms;i){for(j0;j<2000;j){}} } int main() {//按键中断的初始化key1_it_config();key2_it_config();key3_it_config();while(1){printf("in main pro\n");delay(1…

(人才测评)自媒体运营的招聘入职测评方案

互联网如今发展的如此之快&#xff0c;各种信息爆炸&#xff0c;各种手机游戏量产的时代&#xff0c;除此之外还有一些新兴的岗位诞生&#xff0c;那就是自媒体行业&#xff0c;可以说有了互联网&#xff0c;只要你想做&#xff0c;一个人也可以在网络上发布有趣搞笑的视频&…

WPF使用外部字体,思源黑体,为例子

1.在工程中新建文件夹&#xff0c;命名为“Font"。 2.将下载好的字体文件复制到Font文件夹。 3.在工程中&#xff0c;加入静态资源 <Window.Resources><FontFamily x:Key"SYBold">/AnalyzeImage;Component/Font/#思源黑体 CN Bold</FontFamily…

Ecmascript 和javascript的区别

ECMAScript 是什么&#xff1f; 想象一下&#xff0c;ECMAScript&#xff08;简称ES&#xff09;是个“剧本”&#xff0c;规定了“舞台剧”的基本表演规则和动作。在这个比喻中&#xff0c;“舞台剧”就是我们常说的JavaScript。ECMAScript是由欧洲计算机制造商协会&#xff0…

【保姆级教程】YOLOv8_Cls图像分类:训练自己的数据集

一、YOLOV8环境准备 1.1 下载安装最新的YOLOv8代码 仓库地址&#xff1a; https://github.com/ultralytics/ultralytics1.2 配置环境 pip install -r requirements.txt -i https://pypi.tuna.tsinghua.edu.cn/simple二、数据准备 我这里准备了猫和狗的图片&#xff0c;按类别…

学习周报:文献阅读+Fluent案例+水力学理论学习

目录 摘要 Abstract 文献阅读&#xff1a; 文献摘要 现有问题 研究目的及方法 PINN的设置 NS方程介绍 损失函数 训练方法 实验设置 对照组设置 实验结果展示 点云数、隐藏层数和每个隐藏层的节点数对PINN精度的影响 点云数对PINN的影响&#xff1a; 隐藏层数的影…

喜欢我中文编程吗?这么喜欢中文编程哥们给你来点关键字呗

// chinese_commands.h 太优雅了哥们// 变量类型 #define 整型 int #define 浮点型 float #define 双浮点型 double #define 字符 char #define 长整型 long #define 自动 auto #define 布尔 bool// 修饰符 #define 静态 static #define 常量 const #define 虚拟 virtual #defi…

吴恩达深度学习笔记:神经网络的编程基础2.1-2.4

目录 第一门课&#xff1a;神经网络和深度学习 (Neural Networks and Deep Learning)第二周&#xff1a;神经网络的编程基础 (Basics of Neural Network programming)2.1 二分类(Binary Classification)2.2 逻辑回归(Logistic Regression)2.3 逻辑回归的代价函数&#xff08;Lo…

C++基础之继承(十五)

一.继承的定义 当一个派生类继承一个基类时&#xff0c;需要在派生类的类派生列表中明确的指出它是从哪个基类继承而来的。类派生列表的形式如下&#xff1a; class 派生类 : public/private/protected 基类 { }&#xff1b; 派生类生成的三个步骤&#xff1a; 吸收基类成员…

如何恢复回收站被清空的文件?3个宝藏方法大公开!

“怎么办&#xff1f;不小心把回收站里的文件都清空了&#xff0c;现在没法找回我的重要数据了&#xff0c;有什么比较好的方法吗&#xff1f;快来帮帮我吧&#xff01;” 回收站作为Windows系统中的一个重要功能&#xff0c;可以帮助我们暂时存放删除的文件和文件夹&#xff0…

数据结构——树与二叉树

目录 树与二叉树 1.树的定义 2.树的有关术语 3.二叉树&#xff08;BinaryTree&#xff09; 二叉树的性质&#xff1a; 特殊的二叉树 满二叉树&#xff1a; 完全二叉树 二叉树的存储结构 顺序存储结构 链式存储结构 二叉树以及对应接口的实现 1.二叉树架构搭建 2…