【SpringCloud】多机部署, 负载均衡-LoadBalance

devtools/2024/10/9 5:46:35/

多机部署, 负载均衡-LoadBalance

1. 负载均衡介绍

1.1 问题描述

观察上个章节远程调⽤的代码

在这里插入图片描述

  1. 根据应⽤名称获取了服务实例列表
  2. 从列表中选择了⼀个服务实例

思考: 如果⼀个服务对应多个实例呢? 流量是否可以合理的分配到多个实例呢?

现象观察:

我们再启动2个product-service实例
选中要启动的服务, 右键选择 Copy Configuration…

在这里插入图片描述
在弹出的框中, 选择 Modify options -> Add VM options

在这里插入图片描述

添加 VM options : -Dserver.port=9091

9091 为服务启动的端⼝号, 根据⾃⼰的情况进⾏修改
在这里插入图片描述
现在IDEA的Service窗⼝就会多出来⼀个启动配置, 右键启动服务就可以

在这里插入图片描述
同样的操作, 再启动1个实例, 共启动3个服务

在这里插入图片描述
观察Eureka, 可以看到product-service下有三个实例:

在这里插入图片描述
访问结果:

在这里插入图片描述
通过⽇志可以观察到, 请求多次访问, 都是同⼀台机器.
这肯定不是我们想要的结果, 我们启动多个实例, 是希望可以分担其他机器的负荷, 那么如何实现呢?

解决⽅案:

在这里插入图片描述
在这里插入图片描述
通过⽇志可以看到, 请求被均衡的分配在了不同的实例上, 这就是负载均衡

1.2 什么是负载均衡

负载均衡(Load Balance,简称 LB) , 是⾼并发, ⾼可⽤系统必不可少的关键组件

当服务流量增⼤时, 通常会采⽤增加机器的⽅式进⾏扩容, 负载均衡就是⽤来在多个机器或者其他资源中, 按照⼀定的规则合理分配负载.

⼀个团队最开始只有⼀个⼈, 后来随着⼯作量的增加, 公司⼜招聘了⼏个⼈. 负载均衡就是: 如何把⼯作量均衡的分配到这⼏个⼈⾝上, 以提⾼整个团队的效率

1.3 负载均衡的⼀些实现

上⾯的例⼦中, 我们只是简单的对实例进⾏了轮询, 但真实的业务场景会更加复杂. ⽐如根据机器的配置进⾏负载分配, 配置⾼的分配的流量⾼, 配置低的分配流量低等.

服务多机部署时, 开发⼈员都需要考虑负载均衡的实现, 所以也出现了⼀些负载均衡器, 来帮助我们实现负载均衡.

负载均衡分为服务端负载均衡和客⼾端负载均衡

服务端负载均衡

在服务端进⾏负载均衡的算法分配.

⽐较有名的服务端负载均衡器是Nginx. 请求先到达Nginx负载均衡器, 然后通过负载均衡算法, 在多个服务器之间选择⼀个进⾏访问

在这里插入图片描述

客⼾端负载均衡

在客⼾端进⾏负载均衡的算法分配

负载均衡的功能以库的⽅式集成到客⼾端, ⽽不再是由⼀台指定的负载均衡设备集中提供.

⽐如Spring Cloud的Ribbon, 请求发送到客⼾端, 客⼾端从注册中⼼(⽐如Eureka)获取服务列表, 在发送请求前通过负载均衡算法选择⼀个服务器,然后进⾏访问.

Ribbon是Spring Cloud早期的默认实现, 由于不维护了, 所以最新版本的Spring Cloud负载均衡集成的是Spring Cloud LoadBalancer(Spring Cloud官⽅维护)

在这里插入图片描述
客⼾端负载均衡和服务端负载均衡最⼤的区别在于服务清单所存储的位置

2. Spring Cloud LoadBalancer


http://www.ppmy.cn/devtools/121086.html

相关文章

C语言日志类库 zlog 使用指南(第四章 Syslog模式)

第四章 Syslog模式 在zlog中,有三个重要概念:分类(Category)、规则(Rule)和格式(Format)。 4.1 分类、规则和格式 分类(Category):用于指定不同…

Leetcode: 0081-0090题速览

Leetcode: 0081-0090题速览 本文材料来自于LeetCode solutions in any programming language | 多种编程语言实现 LeetCode、《剑指 Offer(第 2 版)》、《程序员面试金典(第 6 版)》题解 遵从开源协议为知识共享 版权归属-相同方式…

mysql学习教程,从入门到精通,SQL 表的创建(33)

1、SQL 表的创建 在SQL中,创建表的基本语法是使用CREATE TABLE语句。以下是一个基本的CREATE TABLE语法模板,以及对其各个部分的解释: CREATE TABLE 表名 (列名1 数据类型 [约束条件] [默认值],列名2 数据类型 [约束条件] [默认值],...[表级…

python字典里面的get方法

在Python中,字典(dict)对象的 get 方法用于从字典中获取指定键(key)对应的值(value)。这个方法会返回字典中键对应的值,如果键不存在于字典中,则返回一个默认值&#xff…

【Kubernetes】常见面试题汇总(五十二)

目录 116. K8S 集群服务暴露失败? 117.外网无法访问 K8S 集群提供的服务? 特别说明: 题目 1-68 属于【Kubernetes】的常规概念题,即 “ 汇总(一)~(二十二)” 。 题目 69-…

C语言复习概要(一)

本文 C语言入门详解:从基础概念到分支与循环1. C语言常见概念1.1 程序的基本结构1.2 变量作用域和存储类1.3 输入输出1.4 编译与运行 2. C语言中的数据类型和变量2.1 基本数据类型2.2 变量的声明与初始化2.3 常量与枚举 3. C语言的分支结构3.1 if语句3.2 if-else语句…

每日OJ题_牛客_游游的水果大礼包_枚举_C++_Java

目录 牛客_游游的水果大礼包 题目解析 C代码 Java代码 牛客_游游的水果大礼包 游游的水果大礼包 (nowcoder.com) 描述: 游游有n个苹果,m个桃子。她可以把2个苹果和1个桃子组成价值a元的一号水果大礼包,也可以把1个苹果和2个桃子…

JVM 基本组成

1.为什么要学习JVM? 未来在工作场景中,也许你会遇到以下场景:线上系统突然宕机,系统无法访问,甚至直接OOM;线上系统响应速度太慢,优化系统性能过程中发现CPU占用过高,原因也许是因为…