当前位置: 首页 > news >正文

面试题-springcloud中的负载均衡是如何实现的?

一句话导读

        Springcloud中的负载均衡是通过Ribbon实现的,自带有很多负载均衡策略,如:包括轮询(Round Robin)、随机(Random)、加权轮询(Weighted Round Robin)、加权随机(Weighted Random)等,亦可自行实现该策略。

目录

一句话导读

一、负载均衡的定义

二、微服务框架Springcloud中的负载均衡职责

        1.实现高可用

      2.实现高并发

       3.实现弹性扩展

        4.实现故障隔离

        5.实现降低延迟

三、策略源码分析:

        1.负载均衡策略(Load Balancing Strategy)

        2.服务列表的动态更新

        3.请求拦截与处理

        4.RestTemplate的增强

        5.超时与重试

        6.服务端列表过滤

        7.自定义负载均衡规则

四、ILoadBalancer接口和IRule接口有什么区别呢

        1.ILoadBalancer接口

        2.IRule接口

五、常见的负载均衡策略包括


一、负载均衡的定义

        负载均衡,从字面含义可以理解将负载均衡的分配到各个工作进程中,在计算机领域,负载均衡是非常重要而常见的技术,旨在提高系统的性能、可用性和可靠性。当一个系统服务,需要多台服务器同时提供服务时,负载均衡可以根据一定的算法和策略将请求分发给这些服务器,使得每台服务器的负载尽量保持平衡,避免某台服务器过载而导致性能下降或故障。负载均衡根据逻辑处理的所属不同,分为客户端负载均衡和服务端负载均衡。

        客户端负载均衡是指负载均衡的决策发生在客户端,当客户端需要访问一个服务时,自己通过相应的策略决定要调用那个远程服务机器,服务端负载均衡则是说负载策略的决策是在服务端,当客户端发起请求,服务端接收到请求后根据相应的策略来判断将请求转发到那个服务机器中。       

        Springcloud的负载均衡就是客户端负载均衡,Nginx、HA Proxy等则是服务端负载均衡。

二、微服务框架Springcloud中的负载均衡职责

        微服务框架Springcloud中的负载均衡是由Ribbon这个组件来实现的,集成的是由Netflix公司提供的spring-cloud-starter-netflix-ribbon。Springcloud通过Ribbon结合服务注册发现机制,实现客户端负载均衡策略。

        在微服务框架中,架构设计时面临的不可避免的一个问题就是高可用、高性能、高并发的需求,在实践过程中,不管是横向扩展、还是提供可用性都是通过负载均衡策略实现的,在Springcloud中他的职责可以分为:

        1.实现高可用

        在Springcloud框架中,同一个微服务功能可能会部署多个服务实例去处理相同的问题,这样当其中一个或多个出现故障,负载均衡策略将不可用的服务实例下线,请求不会被分发到故障机器中,这样其他实例还能正常提供服务,从而实现高可用性。

      2.实现高并发

        通过负载均衡机制,多实例可以同时提供服务,并且请求能够均衡的分配到不同的机器中,实现高并发性

       3.实现弹性扩展

        在服务提供过程中,当某个服务的性能达到上限时,可以根据需求扩展新的服务实例,负载均衡策略会将新的实例一起纳入服务,从而达到弹性扩展的效果

        4.实现故障隔离

        在微服务架构中,一个服务实例的故障不应该影响其他服务实例的正常运行。使用负载均衡可以将请求转发到其他可用的实例,从而实现故障隔离,提高系统的容错性。

        5.实现降低延迟

        通过选择距离用户较近或负载较轻的服务实例来处理请求,负载均衡可以降低请求的延迟,提高用户体验

三、策略源码分析:

        上文说到springcloud中的负载均衡是通过Ribbon实现的,那么我们分析下Ribbon他到底是怎么实现负载均衡的呢?

        从源码的分析中可以看出主要包含几个方面:负载均衡策略的实现、服务列表的动态更新、请求的拦截与处理等

        1.负载均衡策略(Load Balancing Strategy)

        Ribbon中定义了多种负载均衡策略,包括轮询(Round Robin)、随机(Random)、加权轮询(Weighted Round Robin)、加权随机(Weighted Random)等。每种策略都实现了ILoadBalancer接口,通过选择最优的服务实例来实现负载均衡。

        2.服务列表的动态更新

        Ribbon会与Spring Cloud的服务注册与发现组件(如Eureka)结合使用,通过定时拉取注册中心的服务列表信息,并将其缓存在本地。同时,Ribbon会通过监听注册中心的事件来实时更新服务列表,保持服务实例的最新状态。

        3.请求拦截与处理

        在Ribbon中,使用拦截器模式(Interceptors)来对请求进行预处理。Ribbon拦截器可用于实现请求的重试、超时设置、请求头添加等功能。这些拦截器可以灵活地组合使用,以满足不同场景的需求。

        4.RestTemplate的增强

        Ribbon对Spring的RestTemplate进行了增强,通过@LoadBalanced注解标记的RestTemplate,可以在发起请求时自动实现负载均衡。Ribbon在拦截器链中加入了LoadBalancerInterceptor,它负责根据负载均衡策略选择服务实例,并将请求转发到选定的实例上。

        5.超时与重试

        Ribbon支持设置请求的超时时间和重试次数,以增强服务的可靠性和容错性。当请求超时或失败时,Ribbon可以根据配置的重试次数,重新选择一个可用的服务实例进行重试。

        6.服务端列表过滤

        Ribbon提供了服务端列表过滤的功能,可以通过IRule接口实现自定义的过滤规则,例如根据服务端实例的标签、元数据等条件来过滤服务列表,从而实现更加灵活的负载均衡策略。

        7.自定义负载均衡规则

        Ribbon还允许用户根据实际需求自定义负载均衡规则。通过实现IRule接口,用户可以实现自己的负载均衡算法,并在配置中指定使用该规则。

四、ILoadBalancer接口和IRule接口有什么区别呢

        ILoadBalancer接口和IRule接口都是Ribbon负载均衡组件中的关键接口,但它们在功能和作用上有一些区别。 ILoadBalancer接口负责服务实例的管理和选择,而IRule接口负责负载均衡的规则定义。这两个接口共同协作,实现了Ribbon负载均衡组件的核心功能。用户可以通过实现这两个接口,来定制自己的负载均衡策略和规则。

        1.ILoadBalancer接口

         ILoadBalancer接口是Ribbon负载均衡组件的核心接口,它定义了负载均衡器的基本功能。负载均衡器用于选择可用的服务实例,以实现请求的负载均衡。ILoadBalancer接口主要包含以下几个重要方法:

  • chooseServer:根据负载均衡策略选择一个可用的服务实例。负载均衡策略可能是轮询、随机、加权轮询等。
  • getAllServers:获取所有注册在负载均衡器中的服务实例列表。
  • getServerList:获取可用的服务实例列表。
  • getReachableServers:获取处于可达状态的服务实例列表。
  • getServer:根据服务实例的ID获取对应的服务实例。

        ILoadBalancer接口的实现类通常会从服务注册中心(如Eureka)获取可用的服务实例列表,并根据负载均衡策略选择一个实例来处理请求。

        2.IRule接口

        IRule接口是Ribbon负载均衡组件的规则接口,它定义了负载均衡的规则和策略。负载均衡规则用于决定如何从服务实例列表中选择一个实例来处理请求。IRule接口主要包含以下方法:

  • choose:根据特定的规则和策略选择一个服务实例。
  • 通过实现IRule接口,用户可以自定义负载均衡的规则,例如根据服务实例的权重、标签、性能指标等进行选择。Ribbon默认提供了一些常用的负载均衡规则,如轮询(Round Robin)、随机(Random)等。

五、常见的负载均衡策略包括

  1. 轮询(Round Robin):按照顺序依次将请求分发给每台服务器。
  2. 随机(Random):随机选择一台服务器处理请求。
  3. 加权轮询(Weighted Round Robin):根据服务器的权重来分配请求,权重越高的服务器会接收到更多的请求。
  4. 加权随机(Weighted Random):根据服务器的权重来随机选择一台服务器处理请求,权重越高的服务器被选中的概率越大。
  5. 最少连接(Least Connections):选择当前连接数最少的服务器来处理请求。

相关文章:

面试题-springcloud中的负载均衡是如何实现的?

一句话导读 Springcloud中的负载均衡是通过Ribbon实现的,自带有很多负载均衡策略,如:包括轮询(Round Robin)、随机(Random)、加权轮询(Weighted Round Robin)、加权随机&…...

flink的ProcessWindowFunction函数的三种状态

背景 在处理窗口函数时,ProcessWindowFunction处理函数可以定义三个状态: 富函数getRuntimeContext.getState, 每个key每个窗口的状态context.windowState(),每个key的状态context.globalState,那么这几个状态之间有什么关系呢? …...

day50-springboot+ajax分页

分页依赖&#xff1a; <dependency> <groupId>com.github.pagehelper</groupId> <artifactId>pagehelper-spring-boot-starter</artifactId> <version>1.0.0</version> </dependency> 配置&#xff1a; …...

Win7 专业版Windows time w32time服务电脑重启后老是已停止

环境&#xff1a; Win7 专业版 问题描述&#xff1a; Win7 专业版Windows time w32time服务电脑重启后老是已停止 解决方案&#xff1a; 1.检查启动Remote Procedure Call (RPC)、Remote Procedure Call (RPC) Locator&#xff0c;DCOM Server Process Launcher这三个服务是…...

全网最强,接口自动化测试-token登录关联实战总结(超详细)

目录&#xff1a;导读 前言一、Python编程入门到精通二、接口自动化项目实战三、Web自动化项目实战四、App自动化项目实战五、一线大厂简历六、测试开发DevOps体系七、常用自动化测试工具八、JMeter性能测试九、总结&#xff08;尾部小惊喜&#xff09; 前言 在PC端登录公司的…...

OLAP ModelKit Crack,ADO.NET和IList

OLAP ModelKit Crack,ADO.NET和IList OLAP ModelKit是一个多功能的.NET OLAP组件&#xff0c;用C#编写&#xff0c;只包含100%托管代码。它具有XP主题的外观&#xff0c;并能够使用任何.NET数据源(ADO.NET和IList)。借助任何第三方组件(尤其是图表组件)呈现数据的能力扩展了产品…...

4 三组例子,用OpenCV玩转图像-AI-python

读取&#xff0c;缩放&#xff0c;旋转&#xff0c;写入图像 首先导入包&#xff0c;为了显示导入matplotlib/为了在matplotlib显示 导入CV2/查看版本 导入图片/查看图片类型 图片数组 数组大小 对于opencv通道顺序蓝色B、绿色G、红色R matplotlib通道顺序为 红色R、绿色G、蓝…...

计算机网络-三种交换方式

计算机网络-三种交换方式 电路交换(Circuit Switching) 电话交换机接通电话线的方式称为电路交换从通信资源分配的角度来看&#xff0c;交换(Switching)就是按照某种方式动态的分配传输线路的资源 电话交换机 为了解决电话之间通信两两之间连线过多&#xff0c;所以产生了电话…...

03 制作Ubuntu启动盘

1 软碟通 我是用软碟通制作启动盘。安装软碟通时一定要把虚拟光驱给勾选上&#xff0c;其余两个可以看你心情。 2 镜像文件 我使用清华镜像网站找到的Ubuntu镜像文件。 Index of /ubuntu-releases/ | 清华大学开源软件镜像站 | Tsinghua Open Source Mirror 请自己选择镜像…...

【JavaSE】String类中常用的字符串方法(超全)

目录 1.求字符串的长度 2.判断字符串是否为空 3.String对象的比较 3.1 判断字符串是否相同 3.2 比较字符串大小 3.3 忽略大小写比较 4.字符串查找 5.转化 5.1 数值和字符串转化 5.1.1 数字转字符串 valueof 5.1.2 valueOf的其他用法 5.1.3 字符串转数字 5.2 大小写转…...

Bootload U-Boot分析

Bootloader是在操作系统运行之前执行的一段小程序。通过这段小程序可以初始化硬件设备、建立内存空间的映射表&#xff0c;从而建立适当的系统软硬件环境&#xff0c;为最终调用操作系统内核做好准备。 对于嵌入式系统&#xff0c;Bootloader是基于特定硬件平台来实现的。因此…...

以公益之行,筑责任之心——2023年中创算力爱心公益助学活动

捐资助学是一项功在当代、利在千秋的义举。 高考录取工作已经开始&#xff0c;一张张高校录取通知书也陆续送达各位准大学生手中。当他们怀揣着对大学的好奇与憧憬&#xff0c;准备迈进理想的大学时&#xff0c;还有一群人&#xff0c;他们渴望知识&#xff0c;却因经济困难而…...

【机器学习】处理样本不平衡的问题

文章目录 样本不均衡的概念及影响样本不均衡的解决方法样本层面欠采样 &#xff08;undersampling&#xff09;过采样数据增强 损失函数层面模型层面采样集成学习 决策及评估指标 样本不均衡的概念及影响 机器学习中&#xff0c;样本不均衡问题经常遇到&#xff0c;比如在金融…...

Android前沿技术?Jetpack如何?

Jetpack Compose是Android开发领域的一项前沿技术&#xff0c;它提供了一种全新的方式来构建用户界面。近年来&#xff0c;Jetpack Compose在各大招聘等网站上的招聘岗位逐渐增多&#xff0c;薪资待遇也相应提高。本文将从招聘岗位的薪资与技术要求入手&#xff0c;分析Jetpack…...

为react项目添加开发/提交规范(前端工程化、eslint、prettier、husky、commitlint、stylelint)

因历史遗留原因&#xff0c;接手的项目没有代码提醒/格式化&#xff0c;包括 eslint、pretttier&#xff0c;也没有 commit 提交校验&#xff0c;如 husky、commitlint、stylelint&#xff0c;与其期待自己或者同事的代码写得完美无缺&#xff0c;不如通过一些工具来进行规范和…...

小研究 - MySQL 数据库安全加固技术的研究(一)

随着信息系统的日益普及&#xff0c;后台数据库的安全问题逐步被人们重视起来。以当下热门的MySQL 数据库为例&#xff0c;通过分析数据库的安全机制以及总结数据库面临的安全风险&#xff0c;针对性地提出了相应的加固策略&#xff0c;为数据库的安全加固工作提供了技术支撑。…...

linux安装redis带图详细

如何在Linux系统中卸载Redis 一、使用apt-get卸载Redis sudo apt-get purge redis-server如果使用apt-get安装Redis&#xff0c;可以使用apt-get purge命令完全卸载Redis。其中&#xff0c;purge命令会不仅仅删除Redis二进制文件&#xff0c;还会删除配置文件、数据文件和日志…...

MySql——数据库常用命令

一、关于数据库的操作 查看mysql中有哪些数据库 show databases;显示创建指定数据库MySQL语句 SHOW CREATE DATABASE 数据库名&#xff1a;使用指定数据库 use 数据库名;查看当前使用的是哪个数据库 select database();查看指定数据库下有哪些表 use 数据库名; -- 先选择…...

如何通过 WordPress 数据库启用插件?【进不去后台可用】

如果您无法访问 WordPress 后台并需要激活插件以恢复访问权限&#xff0c;则可以通过 WordPress 数据库来实现。本文将向您展示如何使用数据库轻松激活 WordPress 插件。 何时使用数据库激活 WordPress 插件&#xff1f; 许多常见的 WordPress 错误会阻止网站所有者访问 WordP…...

芯片热处理设备 HTR-4立式4寸快速退火炉

HTR-4立式4寸快速退火炉 HTR-4立式4寸快速退火炉&#xff08;芯片热处理设备&#xff09;广泛应用在IC晶圆、LED晶圆、MEMS、化合物半导体和功率器件等多种芯片产品的生产&#xff0c;和欧姆接触快速合金、离子注入退火、氧化物生长、消除应力和致密化等工艺当中&#xff0c;通…...

OpenLayers 可视化之热力图

注&#xff1a;当前使用的是 ol 5.3.0 版本&#xff0c;天地图使用的key请到天地图官网申请&#xff0c;并替换为自己的key 热力图&#xff08;Heatmap&#xff09;又叫热点图&#xff0c;是一种通过特殊高亮显示事物密度分布、变化趋势的数据可视化技术。采用颜色的深浅来显示…...

理解 MCP 工作流:使用 Ollama 和 LangChain 构建本地 MCP 客户端

&#x1f31f; 什么是 MCP&#xff1f; 模型控制协议 (MCP) 是一种创新的协议&#xff0c;旨在无缝连接 AI 模型与应用程序。 MCP 是一个开源协议&#xff0c;它标准化了我们的 LLM 应用程序连接所需工具和数据源并与之协作的方式。 可以把它想象成你的 AI 模型 和想要使用它…...

基于数字孪生的水厂可视化平台建设:架构与实践

分享大纲&#xff1a; 1、数字孪生水厂可视化平台建设背景 2、数字孪生水厂可视化平台建设架构 3、数字孪生水厂可视化平台建设成效 近几年&#xff0c;数字孪生水厂的建设开展的如火如荼。作为提升水厂管理效率、优化资源的调度手段&#xff0c;基于数字孪生的水厂可视化平台的…...

MySQL 8.0 OCP 英文题库解析(十三)

Oracle 为庆祝 MySQL 30 周年&#xff0c;截止到 2025.07.31 之前。所有人均可以免费考取原价245美元的MySQL OCP 认证。 从今天开始&#xff0c;将英文题库免费公布出来&#xff0c;并进行解析&#xff0c;帮助大家在一个月之内轻松通过OCP认证。 本期公布试题111~120 试题1…...

Android Bitmap治理全解析:从加载优化到泄漏防控的全生命周期管理

引言 Bitmap&#xff08;位图&#xff09;是Android应用内存占用的“头号杀手”。一张1080P&#xff08;1920x1080&#xff09;的图片以ARGB_8888格式加载时&#xff0c;内存占用高达8MB&#xff08;192010804字节&#xff09;。据统计&#xff0c;超过60%的应用OOM崩溃与Bitm…...

Element Plus 表单(el-form)中关于正整数输入的校验规则

目录 1 单个正整数输入1.1 模板1.2 校验规则 2 两个正整数输入&#xff08;联动&#xff09;2.1 模板2.2 校验规则2.3 CSS 1 单个正整数输入 1.1 模板 <el-formref"formRef":model"formData":rules"formRules"label-width"150px"…...

html css js网页制作成品——HTML+CSS榴莲商城网页设计(4页)附源码

目录 一、&#x1f468;‍&#x1f393;网站题目 二、✍️网站描述 三、&#x1f4da;网站介绍 四、&#x1f310;网站效果 五、&#x1fa93; 代码实现 &#x1f9f1;HTML 六、&#x1f947; 如何让学习不再盲目 七、&#x1f381;更多干货 一、&#x1f468;‍&#x1f…...

SiFli 52把Imagie图片,Font字体资源放在指定位置,编译成指定img.bin和font.bin的问题

分区配置 (ptab.json) img 属性介绍&#xff1a; img 属性指定分区存放的 image 名称&#xff0c;指定的 image 名称必须是当前工程生成的 binary 。 如果 binary 有多个文件&#xff0c;则以 proj_name:binary_name 格式指定文件名&#xff0c; proj_name 为工程 名&…...

云原生安全实战:API网关Kong的鉴权与限流详解

&#x1f525;「炎码工坊」技术弹药已装填&#xff01; 点击关注 → 解锁工业级干货【工具实测|项目避坑|源码燃烧指南】 一、基础概念 1. API网关&#xff08;API Gateway&#xff09; API网关是微服务架构中的核心组件&#xff0c;负责统一管理所有API的流量入口。它像一座…...

在Mathematica中实现Newton-Raphson迭代的收敛时间算法(一般三次多项式)

考察一般的三次多项式&#xff0c;以r为参数&#xff1a; p[z_, r_] : z^3 (r - 1) z - r; roots[r_] : z /. Solve[p[z, r] 0, z]&#xff1b; 此多项式的根为&#xff1a; 尽管看起来这个多项式是特殊的&#xff0c;其实一般的三次多项式都是可以通过线性变换化为这个形式…...