5分钟学会Ribbon负载均衡

文章目录

  • 一、Ribbon
    • 1.1 Ribbon的负载均衡流程:
    • 1.2 负载均衡策略
      • 1.2.1 内置的负载均衡策略
      • 1.2.2 如何修改负载均衡
    • 1.3 加载方式

一、Ribbon

在这里插入图片描述

1.1 Ribbon的负载均衡流程:

  1. 获取可用的服务列表:客户端在进行服务调用之前,首先需要获取可用的服务实例列表。一般情况下,客户端会向注册中心(例如Eureka)发起查询请求,获取同一服务的多个实例的地址和端口号等信息,以便后续的负载均衡。
  2. 选择负载均衡策略:Ribbon提供了多种负载均衡算法,包括轮询、随机、加权随机、最少连接数等。客户端根据实际需求选择相应的负载均衡策略,并将该策略的实现类注入到RestTemplate或FeignClient等HTTP客户端中。
  3. 发送请求:当应用程序需要发起请求时,HTTP客户端(例如RestTemplate或FeignClient)会使用注入的负载均衡策略来选择一个可用的服务实例。Ribbon会在可用的服务实例列表中选择一个实例,并将请求发送到该实例。
  4. 处理响应:选择的服务实例接收到请求并处理后,会返回响应。Ribbon会将响应传递回应用程序,完成本次服务调用。

Ribbon还支持服务实例的健康检查和动态服务实例的添加和删除等功能。如果某个服务实例无法正常工作,Ribbon会将其从可用服务列表中剔除,并选择其他健康的服务实例。如果有新的服务实例加入,Ribbon会自动将其加入可用服务列表中,以便后续的负载均衡。

1.2 负载均衡策略

1.2.1 内置的负载均衡策略

内置的负载均衡策略说明
RoundRobinRule(轮询规则)按照轮询的方式依次选择可用的服务实例。该规则适用于所有的负载均衡场景,但可能会因为实例响应时间不同而导致负载不均衡的情况。
RandomRule(随机规则)随机选择一个可用的服务实例。该规则适用于需要随机分配负载的场景,例如有些服务实例处理能力比较强,可以通过加权来解决负载不均衡的问题。
WeightedResponseTimeRule(加权响应时间规则)根据服务实例的响应时间和权重来进行负载均衡。响应时间越短的实例被选择的概率越大,而权重越大的实例被选择的概率也越大。该规则适用于需要快速响应的场景。
BestAvailableRule(最佳可用规则)选择最少正在并发请求的服务实例,即最空闲的实例。该规则适用于服务实例处理能力相差比较大的场景。
AvailabilityFilteringRule(可用过滤规则)过滤掉一些故障实例和高并发实例,选择剩余实例中最小响应时间的实例进行负载均衡。该规则适用于需要快速响应的场景。
ZoneAvoidanceRule(区域避免规则)避免选择与当前客户端在同一区域内的实例,以提高容错能力。该规则适用于跨区域调用服务的场景。
RetryRule(重试规则)在请求失败时,会自动重试。该规则适用于需要提高调用成功率的场景,但可能会导致请求的响应时间变长。

1.2.2 如何修改负载均衡

通过定义IRule实现可以修改负载均衡规则,有两种方式:

  1. 代码方式:在启动类中,定义一个新的IRule:
@Bean
public IRule randomRule(){
	return new RandomRule();
}

作用全局

  1. 配置文件方式:在yml文件中,添加新的配置也可以修改规则:
userservice:
  ribbon:
    NFLoadBalancerRuleClassName: com.netflix.loadbalancer.RandomRule

作用指定服务

1.3 加载方式

在使用Ribbon进行负载均衡时,存在两种不同的加载方式:懒加载和饥饿加载。

  1. 懒加载

懒加载是指在第一次请求到达时,才会初始化负载均衡器并进行服务实例的获取和负载均衡计算。也就是说,在应用程序启动时,并不会立即初始化负载均衡器和服务实例列表,只有在第一次请求到达时,才会进行初始化和计算。

这种方式的优点是可以节省资源,因为在应用程序启动时不需要立即初始化和计算,只有当需要使用负载均衡器时,才进行初始化和计算。但是缺点是,由于需要在第一次请求到达时初始化,可能会造成请求的延迟。

可以通过设置ribbon.eager-load.enabled=false属性来禁用懒加载,使用饥饿加载方式。

  1. 饥饿加载

饥饿加载是指在应用程序启动时,就会立即初始化负载均衡器和服务实例列表,并进行负载均衡计算。也就是说,无论是否有请求到达,都会进行初始化和计算。

这种方式的优点是可以提高请求的响应速度,因为负载均衡器和服务实例列表已经提前初始化,不需要等待第一次请求到达时再进行初始化和计算。但是缺点是会占用一定的资源,因为在应用程序启动时就需要初始化和计算。

可以通过设置ribbon.eager-load.enabled=true属性来启用饥饿加载方式。

  • 如果希望节省资源并可以容忍一定的请求延迟,可以选择懒加载方式;
  • 如果希望提高请求的响应速度,可以选择饥饿加载方式。

示例:

ribbon:
  eager-load:
    enabled: true #开启饥饿加载
    clients: # 指定饥饿加载的服务名称
      -xxxservice
      -xxxservice

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

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

相关文章

如何基于ChatGPT+Avatar搭建24小时无人直播间

0 前言 最近朋友圈以及身边很多朋友都在研究GPT开发,做了各种各样的小工具小Demo,AI工具用起来是真的香!在他们的影响下,我也继续捣鼓GPT Demo,希望更多的开发者加入一起多多交流。 上一篇结合即时通 IM SDK捣鼓了一个…

SpringAOP入门基础银行转账实例(进阶版)------------事务处理

SpringAOP入门基础银行转账实例**(进阶版)**------------事务处理 由上一节讲述的通过Connection和QueryRunner对事务进行的处理(详情可以去我之前写的博客文章:https://blog.csdn.net/m0_56245143/article/details/130069160?spm1001.2014…

VMware vSphere 8.0c - 企业级工作负载平台

ESXi 8.0.0 & vCenter Server 8.0.0 GA (General Availability) 请访问原文链接:https://sysin.org/blog/vmware-vsphere-8/,查看最新版。原创作品,转载请保留出处。 作者主页:sysin.org 2023-03-30, VMware vSphere 8.0c 发…

静态库与动态库

库是已经写好的、成熟的、可复用的代码。在我们的开发的应用中经常有一些公共代码是需要反复使用的,就把这些代码编译为库文件。库可以简单看成一组目标文件的集合,将这些目标文件经过压缩打包之后形成的一个可执行代码的二进制文件。库有两种&#xff1…

Ubuntu硬盘分区、挂载

文章目录1、使用命令查看硬盘情况2、分区3、格式化分区4、挂载手动挂载自动挂载1、使用命令查看硬盘情况 sudo fdisk -l 可以看到这里有个未分区的4T硬盘 如:sdb 这样的是硬盘 sdb1 sdb2 这样的是分区,现在还没分区 2、分区 sudo parted /dev/sdb (s…

一切都是命中注定的!

“光锥之内就是命运”,这是刘慈欣的《三体黑暗森林》里一句话,如果我们看到一件事情正在发生,那么它早在过去无论是几秒前还是几千年前,就已经发生了,我们无法改变这个命运。 孔明叹曰:“谋事在人&#xf…

树莓派通过网线连接笔记本实现笔记本电脑Wifi的网络共享

基于windows电脑连接树莓派进行设置:通过通过一根网线,连接树莓派和电脑,使电脑和树莓派构成一个局域网,然后树莓派接收来自笔记本电脑wifi网络的共享网络。操作方法类似台式机通过网线共享笔记本电脑无线网络的步骤 1、 保证笔记…

总结816

学习目标: 4月(复习完高数18讲内容,背诵21篇短文,熟词僻义300词基础词) 学习内容: 高等数学:一元积分,算是彻底过一遍了,但还是需要再回顾一遍。今日一道变限积分求导出…

简单的单目测距实验

一、原理 简单的单目测距方法,假设相机平面和物体平面平行,相机正对着物体表面拍摄,则可以利用相似三角形法。 用相似三角形计算物体或者目标到相机的距离,将使用相似三角形来计算相机到一个已知的物体或者目标的距离。 假设有…

执行数学的运算

数学是计算机编程的重要能力。遗憾的是,对shell脚本来说,这个处理过程比较麻烦。在shell脚本中两种途径来进行数学运算。 expr命令 最开始,Bourne shell提供了一个特别的命令用来处理数学表达式。expr命令允许在命令行上处理数学数学表达式。…

算法学习day59

算法学习day591.力扣503.下一个更大元素II1.1 题目描述1.2 分析1.3代码2.力扣42. 接雨水2.1 题目描述2.2 分析2.3 代码3.参考资料1.力扣503.下一个更大元素II 1.1 题目描述 题目描述: 给定一个循环数组(最后一个元素的下一个元素是数组的第一个元素&a…

【Java 并发编程】一文了解线程间有哪些通信方式?

一文了解线程间有哪些通信方式?1. synchronized 内置锁2. volatile 关键字3. 等待/通知机制3.1 等待wait()wait(long)wait(long, int)等待方需遵循如下原则3.2 通知notify()notifyAll()通知方需遵循如下原则notify() 和 notifyAll() 应该用谁?4. 管道输入…

BusterNet网络Python模型实现学习笔记一

实在是无力吐槽了,心力交瘁。作者Github仓库给了错误的 USCISI-CMFD-Small 数据集。自己捣鼓了半天,发现原来是压缩之后数据集,也就是 LMDB 文件格式出错了。实在是误人子弟,自己已经气急败坏了现在… 但是既然论文都花那么长时间…

数据分析之Pandas 基础入门

一、初始Pandas pandas 是数据分析三大件之一,是Python的核心分析库,它提供了快捷、灵活、明确的数据结构,它能够简单、直观、快速的处理各种类型的数据结构。 pandas 支持的数据结构如下: SQL 或Excel 类似的数据有序或无序的…

【学习笔记】unity脚本学习(三)(向量 Vector3)

目录向量复习高中向量基础【数学】向量的四则运算、点积、叉积、正交基叉乘公式叉乘运算定理向量、坐标系点积叉积Vector3 三维向量静态变量变量变量normalized 与 Normalize() 方法静态方法ClampMagnitudeCrossDistanceDotMoveTowards其他变换类似Lerp 在两个点之间进行线性插…

实现一个简单但有趣的AR效果(Web)

有人说:一个人从1岁活到80岁很平凡,但如果从80岁倒着活,那么一半以上的人都可能不凡。 生活没有捷径,我们踩过的坑都成为了生活的经验,这些经验越早知道,你要走的弯路就会越少。

MySQL 库操作

目录 创建数据库 语法 案例 字符集和校验规则(建数据库/建表用) 查看系统默认字符集以及校验规则 db.opt 更改 查看数据库支持的字符集 查看数据库支持的字符集校验规则 校验规则对数据库的影响 排升序 操纵数据库 查看数据库 显示创建语…

洛谷P2822:组合数问题 ←(帕斯卡法则+取模+前缀和)

【题目来源】https://www.luogu.com.cn/problem/P2822https://www.acwing.com/problem/content/525/【题目描述】 组合数​表示的是从n个物品中选出m个物品的方案数。举个例子:从(1,2,3)三个物品中选择两个物品可以有(1,2),(1,3),(2,3) 这三种…

MySQl_1

一.相关概念 数据库:存放数据的仓库 数据库管理系统:操作和管理数据库的大型软件,如mysql SQL:一种操作 关系型数据库管理系统的语言,定义了一套操作关系型数据库管理系统的统一标准。 关系型数据库:有多…

客户案例 | 迎接智能化浪潮,传统水厂数字化势在必行

关键发现 客户痛点:传统水厂业务离散,无法实现数据实时同步,为收集和分析处理数据并辅助决策带来障碍。需要智能化管理系统帮助水厂提升管理效率,优化管理流程,实现数字化、智能化的目标。 解决方案:天津腾…