面试题-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):选择当前连接数最少的服务器来处理请求。

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

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

相关文章

服务器被攻击了怎么办?

服务器被攻击是无法避免的,但是我们能通过做好防护措施,提高服务器的安全性,降低被攻击的几率。那么当服务器已经被 攻击了,怎样才能降低损失呢?该怎样补救? 断开网络 全部的攻击都来自于网络,因…

Docker-compose应用

Docker-compose Docker-compose 是Dcoker官方推出的Docker容器的一键编排工具,使用Docker-compose可以批量启动容器、停止容器等等。 安装 github地址 https://github.com/docker/compose/tree/v2.20.1 下载地址 https://github.com/docker/compose/releases …

人大金仓数据库Docker部署

docker 搭建 yum -y install yum-utilsyum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.reposystemctl start docker.servicesystemctl enable docker.servicesystemctl status docker.service 配置Docker cd /etc/docker/ vi da…

免费的scrum敏捷开发管理工具

Scrum中非常强调公开、透明、直接有效的沟通,这也是“可视化的管理工具”在敏捷开发中如此重要的原因之一。通过“可视化的管理工具”让所有人直观的看到需求,故事,任务之间的流转状态,可以使团队成员更加快速适应敏捷开发流程。 …

Spring Authorization Server入门 (十五) 分离授权确认与设备码校验页面

前言 在之前的文章(实现授权码模式使用前后端分离的登录页面)中实现了前后端分离的登录页面,但这篇文章中只分离了登录页面,鉴于部分读者好奇授权确认页面分离的实现,就实现一下授权确认页面的分离,同时设备码流程的授权确认页面与…

JVM系统优化实践(24):ZGC(一)

您好,这里是「码农镖局」CSDN博客,欢迎您来,欢迎您再来~ 截止到目前,算上ZGC,Java一共有九种类型的GC,它们分别是: 1、Serial GC 串行/作用于新生代/复制算法/响应速度优先/适用于单…

C++教程 - How to C++系列专栏第0篇

关于专栏 这个专栏是优质的C教程专栏 本专栏一致使用操作系统:macOS Ventura,代码编辑器:CLion,C编译器:Clang 感谢一路相伴的朋友们,感谢你们的支持 ^ _ ^ 博主反馈非常及时,如果你在阅读…

NativePHP:使用PHP构建跨平台桌面应用的新框架

NativePHP是一个用于使用PHP构建桌面应用的框架。它允许PHP开发人员使用熟悉的工具和技术创建跨平台的原生应用。NativePHP具有一系列易于使用的类,一套用于构建和打包应用程序的工具以及一个静态跨平台PHP运行时。 官网地址:https://nativephp.com PH…

真的不想知道录音转文字怎么弄才简单吗

哇哦!听说你想知道如何将录音转成文字?这简直是一个超酷的技能,让我来为你揭开这个神奇的面纱吧!想象一下,当你有一堆录音文件需要处理时,你不再需要费尽心思地一遍遍倾听、抄写。现在,你只需要…

LumenSceneData 初始化 [1]

前置信息: 灯光从World到Scene的流程。 UE4 Lights UWorld to FScene [1]_spawnactor failed because of collision at the spaw_sh15285118586的博客-CSDN博客 mesh从world到Scene流程,与灯光类似 void UStaticMeshComponent::CreateRenderState_Con…

Kubectl 详解

目录 陈述式资源管理方法:项目的生命周期:创建-->发布-->更新-->回滚-->删除声明式管理方法:陈述式资源管理方法: kubernetes 集群管理集群资源的唯一入口是通过相应的方法调用 apiserver 的接口kubectl 是官方的CLI命令行工具,用于与 apiserver 进行通信,将…

基于YOLOv7的密集场景行人检测识别分析系统

密集场景下YOLO系列模型的精度如何?本文的主要目的就是想要基于密集场景基于YOLOv7模型开发构建人流计数系统,简单看下效果图: 这里实验部分使用到的数据集为VSCrowd数据集。 实例数据如下所示: 下载到本地解压缩后如下所示&…

webpack 静态模块打包工具

webpack 为什么? 把静态模块内容,压缩,整合,转译等(前端工程化) 把less/sass转成css代码把ES6 降级成ES5支持多种模块文件类型,多种模块标准语法 vite 为什么不直接学习vite 而学习webpack 因为很多项目还是基于webpack来进…

js 判断对象为数组.html

<!DOCTYPE html> <html lang"en"> <head> <meta charset"UTF-8" /> <title>数组判断</title> </head> <body> <script> function isArray(obj) { /* 判断对象 obj 是否是数组。*/ return typeof o…

vue加载大量数据优化

在Vue中加载大量数据并形成列表时&#xff0c;可以通过以下方法来优化性能&#xff1a; 分页加载&#xff1a;不要一次性加载所有的数据&#xff0c;而是分批加载数据&#xff0c;每次只加载当前页需要显示的数据量。可以使用第三方库如vue-infinite-loading来实现无限滚动加载…

找免费商用的图片素材就上这6个网站。

分享6个免费商用的高清图片素材库&#xff0c;你想要找到这里都能找到&#xff0c;赶紧收藏起来吧~ 菜鸟图库 https://www.sucai999.com/pic.html?vNTYwNDUx 网站主要是为新手设计师提供免费素材的&#xff0c;素材的质量都很高&#xff0c;类别也很多&#xff0c;像平面、UI…

Git Submodule 更新子库失败 fatal: Unable to fetch in submodule path

编辑本地目录 .git/config 文件 在 [submodule “Assets/CommonModule”] 项下 加入 fetch refs/heads/:refs/remotes/origin/

常规VUE项目优化实践,跟着做就对了!

总结&#xff1a; 主要优化方式&#xff1a; imagemin优化打包大小&#xff08;96M->50M&#xff09;&#xff0c;但是以打包速度为代价&#xff0c;通过在构建过程中压缩图片来实现&#xff0c;可根据需求开启。字体压缩&#xff1a;目前项目内引用为思源字体&#xff0c…

认识所有权

专栏简介&#xff1a;本专栏作为Rust语言的入门级的文章&#xff0c;目的是为了分享关于Rust语言的编程技巧和知识。对于Rust语言&#xff0c;虽然历史没有C、和python历史悠远&#xff0c;但是它的优点可以说是非常的多&#xff0c;既继承了C运行速度&#xff0c;还拥有了Java…