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

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

  • 一、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:latestrestart: "always"environment:APP_ENV: developmentports:- "80:80"networks:- my_networkvolumes:-  /etc/nginx/nginx.conf:/etc/nginx/nginx.conf-  /usr/local/nginx/html:/usr/local/nginx/htmlnetworks:my_network:driver: bridgeipam:driver: defaultconfig:- subnet: 172.16.238.0/24gateway: 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:latestrestart: "always"environment:APP_ENV: developmentports:- 80networks:- my_networkvolumes:-  /etc/nginx/nginx.conf:/etc/nginx/nginx.conf-  /usr/local/nginx/html:/usr/local/nginx/htmlnetworks:my_network:driver: bridgeipam:driver: defaultconfig:- subnet: 172.16.238.0/24gateway: 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💖点点关注,收藏不迷路💖

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

微软开源Garnet高性能缓存服务安装

Garnet介绍 Garnet是一款微软研究院基于C#开发而开源的高性能缓存服务&#xff0c;支持Windows、Linux多平台部署&#xff0c;Garnet兼容Redis服务API&#xff0c;在性能和使用架构上较Redis有很大提升&#xff08;官方说法&#xff09;&#xff0c;并提供与Redis一样的命令操…

Rust egui(3) 增加多个tab

话说不知道咋写&#xff0c;要不直接上git patch吧。代码都是移植的官方demo&#xff0c;核心改动就是把原来的line_demo换成了plot_demo&#xff0c;里面实现多个ui&#xff0c;然后点击tab标题会切换不同的ui。 如下图&#xff0c;Lines和Markers两个不同的标签对应不同的ui。…

力扣HOT100 - 11. 盛最多水的容器

解题思路&#xff1a; 双指针&#xff0c;从左右两边往内侧夹逼&#xff0c;遍历后得到最大值 class Solution {public int maxArea(int[] height) {int i 0, j height.length - 1, res 0;while(i < j) {res height[i] < height[j] ? Math.max(res, (j - i) * heig…

【C++】关联式容器——map和set

1 关联式容器 STL中我们常用的部分容器&#xff0c;比如&#xff1a;vector、list、deque、forward_list(C11)等&#xff0c;这些容器统称为序列式容器&#xff0c;因为其底层为线性序列的数据结构&#xff0c;里面存储的是元素本身。 那什么是关联式容器呢&#xff1f;它与序…

qt Qt Remote Object(QtRO)实现进程间通信

简介 Qt Remote Object简称QtRO&#xff0c;这是Qt5.9以后官方推出来的新模块&#xff0c;专门用于进程间通信&#xff08;IPC&#xff09;。是基于Socket来封装的&#xff0c;兼容LPC和RPC。LPC即Local Process Communication&#xff0c;而RPC是指Remote Process Communicat…

Camera入门基础知识

一、camera介绍 1.1 camera硬件组成 camera一般由Lens、VCM音圈马达、底座支架、Sensor、Driver IC、output interface组成。如下图: 这里面要注意的是有些摄像头模组有VCM,有些则没有,有些output interface输出的是CSI信号,有的输出的是串行信号,需要接解串器。…

全新的分布式锁,功能简单且强大

分布式锁是分布式系统中一个极为重要的工具。 目前有多种分布式锁的设计方案&#xff0c;比如借助 redis&#xff0c;mq&#xff0c;数据库&#xff0c;zookeeper 等第三方服务系统来设计分布式锁。 tldb 提供的分布式锁&#xff0c;主要是要简化这个设计的过程&#xff0c;提…

面向对象-继承-使用细节

面向对象-继承-使用细节 1、子类继承了父类所有的属性和方法&#xff0c;非私有的属性和方法可以在子类中直接访问&#xff0c;但是私有的属性和方法不能在子类中直接访问&#xff0c;要通过父类提供公共的方法去访问。 2、子类必须调用父类的构造器&#xff0c;完成对父类的初…

PCB布线中晶振电容、电源大小电容、电源电容的设计细节

嵌入式软硬件爱好者 一张手册走天下。嵌入式单片机/Linux/Openwrt/电子电路技术交流分享。//主打一个技术层面的剑走偏锋&#xff0c;直击众人重视和不重视的重点//专注基础&#xff0c;才能走的更远 晶振电容 晶振旁边的电容在电路设计中不是用于滤波的。实际上&#xff0c;…

RIP,EIGRP,OSPF的区别

1.路由协议 能否选择出最优路径 2.路由协议 是否能够完成故障切换/多久能够完成故障切换 3.路由协议 是否会占用过大硬件资源 -- RIP -- 路由信息协议 跳数:一次三层设备的转发算一跳 中间隔的设备数量 不按照链路带宽来算 Rip认为路径一样,这个时候。 下面这个跳数不…

每日一题 --- 反转链表[力扣][Go]

反转链表 题目&#xff1a;206. 反转链表 给你单链表的头节点 head &#xff0c;请你反转链表&#xff0c;并返回反转后的链表。 示例 1&#xff1a; 输入&#xff1a;head [1,2,3,4,5] 输出&#xff1a;[5,4,3,2,1]示例 2&#xff1a; 输入&#xff1a;head [1,2] 输出&a…

阿里云服务器价格购买价格表,2024新版报价查询

2024年腾讯云服务器优惠价格表&#xff0c;一张表整理阿里云服务器最新报价&#xff0c;阿里云服务器网整理云服务器ECS和轻量应用服务器详细CPU内存、公网带宽和系统盘详细配置报价单&#xff0c;大家也可以直接移步到阿里云CLUB中心查看 aliyun.club 当前最新的云服务器优惠券…

(Linux 学习十二)文件查找和文件压缩

一.文件查找 which 命令查找 也可以用 whereis find 文件查找&#xff0c;针对文件名 locate 文件查找&#xff0c;依赖数据库alias 别名 alias yyy ls --colorauto -l yyy //相当于别名 查看文件which ls //查找ls 命令位置 whereis vim //也是查找命令locate …

Jackson 2.x 系列【2】生成器 JsonGenerator

有道无术&#xff0c;术尚可求&#xff0c;有术无道&#xff0c;止于术。 本系列Jackson 版本 2.17.0 源码地址&#xff1a;https://gitee.com/pearl-organization/study-seata-demo 文章目录 1. 前言2. 案例演示2.1 创建 JsonFactory2.2 创建 JsonGenerator2.3 写入操作2.4 查…

pta-洛希极限

科幻电影《流浪地球》中一个重要的情节是地球距离木星太近时&#xff0c;大气开始被木星吸走&#xff0c;而随着不断接近地木“刚体洛希极限”&#xff0c;地球面临被彻底撕碎的危险。但实际上&#xff0c;这个计算是错误的。 洛希极限&#xff08;Roche limit&#xff09;是一…

javase day11笔记

第十一天课堂笔记 构造代码块 { } 给 所有对象 共性特点 进行初始化操作 创建对象时在堆区对象中存放实例变量,同时执行构造代码块 执行顺序:静态代码块—>非静态代码块—>构造方法 继承★★★ 将多个类中相同的实例变量和实例方法 , 单独存放到一个类中,成为父类…

基于Java中的SSM框架实现快餐店线上点餐系统项目【项目源码+论文说明】计算机毕业设计

基于Java中的SSM框架实现快餐店线上点餐系统演示 摘要 随着计算机互联网的高速发展。餐饮业的发展也加入了电子商务团队。各种网上点餐系统纷纷涌现&#xff0c;不仅增加了商户的销售量和营业额&#xff0c;而且为买家提供了极大的方便&#xff0c;足不出户&#xff0c;就能订…

云计算安全分析

目录 一、概述 二、《云计算服务安全指南》的云安全风险分析 2.1 客户对数据和业务系统的控制能力减弱 2.2 客户与云服务商之间的责任难以界定 2.3 可能产生司法管辖权问题 2.4 数据所有权保障面临风险 2.5 数据保护更加困难 2.6 数据残留 2.7 容易产生对云服务商的过度…

[AIGC] SQL中的数据添加和操作:数据类型介绍

SQL&#xff08;结构化查询语言&#xff09;作为一种强大的数据库查询和操作工具&#xff0c;它能够完成从简单查询到复杂数据操作的各种任务。在这篇文章中&#xff0c;我们主要讨论如何在SQL中添加&#xff08;插入&#xff09;数据&#xff0c;以及在数据操作过程中&#xf…

2021年XX省赛职业院校技能大赛”高职组 计算机网络应用赛项 网络构建模块竞赛真题

“2021年XX省赛职业院校技能大赛”高职组 计算机网络应用赛项 网络构建模块竞赛真题 目录 一&#xff0e;考试说明 1 二&#xff0e;模块B网络构建 2 &#xff08;一&#xff09;任务描述 2 &#xff08;二&#xff09;任务清单 9 一&#xff0e;考试说明 本模块比赛时间为…