5分钟学会Ribbon负载均衡

news2025/1/12 6:13:38

文章目录

  • 一、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

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

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

相关文章

浅谈人工智能在教育行业的应用

人工智能(Artificial Intelligence, AI)是当前最热门的技术领域之一,也是未来的发展趋势之一。人工智能可以用于各种领域,包括医疗、金融、交通、农业等。其中,人工智能在教育行业的应用也备受关注。本文将从人工智能在…

【无功优化】基于改进遗传算法的电力系统无功优化研究【IEEE30节点】(Matlab代码实现)

💥💥💞💞欢迎来到本博客❤️❤️💥💥 🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜密,逻辑清晰,为了方便读者。 ⛳️座右铭&a…

【k8s完整实战教程1】源码管理-Coding

系列文章:这个系列已完结,如对您有帮助,求点赞收藏评论。 读者寄语:再小的帆,也能远航! 【k8s完整实战教程0】前言【k8s完整实战教程1】源码管理-Coding【k8s完整实战教程2】腾讯云搭建k8s托管集群【k8s完…

计算机系统概论

提示:星河不问赶路人,岁月不负有心人 文章目录前言知识1.1 计算机的发展1.2 计算机硬件的基本组成1.3 计算机的性能指标前言知识 机器字长:计算机一次整数运算所能处理的二进制位数 .exe文件就是用机器语言描述的程序 1.1 计算机的发展 计…

LSPosed 安装教程(LSP框架安装教程)

1、下载LSPosed模块 CSDN下载: Riru 版:LSPosed-RiruZygisk版: LSPosed-Zygisk 或 github下载:LSPosed GitHub 2、打开Magisk – 设置 – 开启 Zygisk 3、打开面具 – 模块 – 从本地安装 4、重启设备,通知栏 点开&…

elasticsearch MySQL 数据同步。

elasticsearch & MySQL 数据同步。 文章目录elasticsearch & MySQL 数据同步。3. 数据同步。3.1. 思路分析。3.1.1. 同步调用。3.1.2. 异步通知。3.1.3. 监听 binlog。3.1.4. 选择。3.2. 实现数据同步。3.2.1. 思路。3.2.2. 导入 demo。3.2.3. 声明交换机、队列。1&…

Ansys Zemax | 模拟 AR 系统中的全息光波导:第二部分

AR 系统通常使用全息图将光耦合到波导中。本文展示了如何继续改进 本系列文章的第一部分 (点击查看)中建模的初步设计。(联系我们获取文章附件) 简介 AR 是一种允许屏幕上的虚拟世界与现实场景结合并交互的技术。 本文演示了如何…

如何学习计算机视觉?

AI的专业领域知识是指AI与具体应用领域相结合时所需要的该应用领域的知识。AI的应用领域非常广泛,例如计算机视觉、智能交通、智能制造、智慧金融、智慧教育、智慧农业、智慧能源、智能通信、智能芯片等。本文主要介绍计算机视觉的基本概念、发展历程、主要研究内容…

HMM-读书笔记

信息提取基础 MM 马卡洛夫链(Markov chain)是处理一类随机过程,这些过程包含最少量的内存,但实际上并不是无记忆的。下面,我们将处理离散随机变量和有限马尔可夫链。令 X1, X2, … , Xn, … 为随机变量序列,它们的值为同样有限字…

LeetCode 654 最大二叉树

题目: 给定一个不重复的整数数组 nums 。 最大二叉树 可以用下面的算法从 nums 递归地构建: 创建一个根节点,其值为nums中的最大值。 递归地在最大值左边的子数组前缀上构建左子树。 递归地在最大值右边的子数组后缀上构建右子树。 返回 nums 构建的最大…

VMware ESXi 8.0c Unlocker OEM BIOS 集成网卡驱动和 NVMe 驱动 (集成驱动版)

发布 ESXi 8.0 集成驱动版,在个人电脑上运行企业级工作负载 请访问原文链接:https://sysin.org/blog/vmware-esxi-8-sysin/,查看最新版。原创作品,转载请保留出处。 作者主页:sysin.org 发布 ESXi 8.0 集成驱动版&am…

在 Python 中计算两个数字之间的百分比

要计算两个数字之间的百分比,请将一个数字除以另一个数字,然后将结果乘以 100,例如 (30 / 75) * 100。这显示第一个数字占第二个数字的百分比。 在示例中,30 是 75 的 40%。 def is_what_percent_of(num_a, num_b):return (num_a…

论Sort()方法在 Python 和 Javascript 中应用的区别

Sort()方法相信大家都熟悉,用于排序,那就是数字从低到高(默认) 和 从高到低。以下对这个排序方法在Python 和 Java Script 中应用的区别作详细的举例说明。 在 Python中,例如有 lst1 : [1,5,8,6,2] ,要对这…

html制作好看的个人简历(附源码)

文章目录1.设计来源1.1 主界面1.2 基本资料页面1.3 个人名言页面1.4 教育经历页面1.5 联系方式页面1.6 自我评价页面1.7 工作经历页面1.8 兴趣爱好页面1.9 沟通交流页面2.效果和源码2.1 动态效果2.2 源代码2.3 相关个人简历源码源码下载作者:xcLeigh 文章地址&#…

java课程设计(学生信息管理系统设计)+数据库

🔍 🔎 本期带领大家一起来学习java课程设计(学生信息管理系统设计)数据库的实现思路 🔍 🔎 文章目录题目要求数据库🌍一 、环境搭建🌍二 、功能实现 🌎 🌍1.学…

重磅!阿里版本【ChatGPT】开放测评!

前两天突然爆出惊人消息:阿里版ChatGPT开放测评了! 在本月初,已经有诸多关于阿里巴巴即将推出类似ChatGPT产品的传闻。 数日前,首批曝光的天猫精灵“鸟鸟分鸟”脱口秀版GPT基于大型模型的“精简版”,凭借其出色的表现吸…

2023-4-11-chrono库用法学习

🍿*★,*:.☆( ̄▽ ̄)/$:*.★* 🍿💥💥💥欢迎来到🤞汤姆🤞的csdn博文💥💥💥💟💟喜欢的朋友可以关注一下&#xff0…

4.9、字节序

4.9、字节序1.简介2.字节序举例3.判断电脑存储方式代码1.简介 现代 CPU 的累加器一次都能装载(至少)4 字节(这里考虑 32 位机),即一个整数。那么这 4字节在内存中排列的顺序将影响它被累加器装载成的整数的值&#xff…

vue element-ui 暗黑主题应用到若依框架

问题描述 基于若依框架的element-ui,将主题更换为暗黑主题。 问题分析 现有的element-ui框架提供的主题不满足自定义需求,大多数框架,包括若依提供了更换主题色的功能,但也只是更换的primary-color,其他组件的主题还…

算法小课堂(五)贪心算法

一、概述 贪心算法是一种常见的算法思想,用于解决优化问题。其基本思想是在每一步选择中都采取当前状态下最优的选择,从而希望能够获得全局最优解。 具体来说,贪心算法通常分为以下步骤: 定义问题的最优解,通常需要将…