微服务篇之负载均衡

一、Ribbon负载均衡流程

二、Ribbon负载均衡策略

**1. RoundRobinRule:**简单轮询服务列表来选择服务器。

**2. WeightedResponseTimeRule:**按照权重来选择服务器,响应时间越长,权重越小。

**3. RandomRule:**随机选择一个可用的服务器。

  1. BestAvailableRule:忽略那些短路的服务器,并选择并发数较低的服务器。

  2. RetryRule:重试机制的选择逻辑。

  3. AvailabilityFilteringRule:可用性敏感策略,先过滤非健康的,再选择连接数较小的实例。

**7. ZoneAvoidanceRule:**以区域可用的服务器为基础进行服务器的选择。使用Zone对服务器进行分类,这个Zone可以理解为一个机房、一个机架等。而后再对Zone内的多个服务做轮询。

三、自定义负载均衡策略

可以自己创建类实现IRule接口 , 然后再通过配置类或者配置文件配置即可 ,通过定义IRule实现可以修改负载均衡规则,有两种方式:

四、面试题及回答

**面试官:**你们项目负载均衡如何实现的 ?

**候选人:**在服务调用过程中的负载均衡一般使用SpringCloud的Ribbon 组件实现 , Feign的底层已经自动集成了Ribbon , 使用起来非常简单。当发起远程调用时,ribbon先从注册中心拉取服务地址列表,然后按照一定的路由策略选择一个发起远程调用,一般的调用策略是轮询。

**面试官:**Ribbon负载均衡策略有哪些 ?

**候选人:**我想想啊,有很多种,我记得几个:

  • RoundRobinRule:简单轮询服务列表来选择服务器。

  • WeightedResponseTimeRule:按照权重来选择服务器,响应时间越长,权重越小。

  • RandomRule:随机选择一个可用的服务器。

  • ZoneAvoidanceRule:区域敏感策略,以区域可用的服务器为基础进行服务器的选择。使用Zone对服务器进行分类,这个Zone可以理解为一个机房、一个机架等。而后再对Zone内的多个服务做轮询(默认)。

**面试官:**如果想自定义负载均衡策略如何实现 ?

**候选人:**提供了两种方式:

  1. 创建类实现IRule接口,可以指定负载均衡策略,这个是全局的,对所有的远程调用都起作用。

  2. 在客户端的配置文件中,可以配置某一个服务调用的负载均衡策略,只是对配置的这个服务生效远程调用。

相关推荐
折哥的程序人生 · 物流技术专研4 小时前
《Java面试85题图解版(三)》上篇:高阶架构设计篇
java·开发语言·后端·面试·职场和发展
小短腿的代码世界4 小时前
QwtPolar 与实时示波器级渲染优化:雷达图到示波器曲线的极限性能调优
前端·qt·架构·交互
吴声子夜歌4 小时前
Java——ArrayDeque
java·arraydeque
NagatoYukee4 小时前
Spring/SpringMVC/SprongBoot知识复习
java·数据库·spring
covco4 小时前
端云协同架构下:AI 原生矩阵系统端侧推理与离线生产技术实践
人工智能·矩阵·架构
飞瀑4 小时前
ASP.NET Core MVC 核心架构深度解析
架构·mvc·.net core
泓博4 小时前
docker ubuntu源码安装openclaw的常见问题
java·linux·开发语言·ai
YuanDaima20484 小时前
WSL2 核心中间件部署实战:MySQL、Redis 与 RocketMQ
java·数据库·人工智能·redis·python·mysql·rocketmq
南境十里·墨染春水4 小时前
线程池学习(一) 理解 进程 线程 协程及上下文切换
java·开发语言·学习
知兀4 小时前
@Accessors(chain = true)和@Builder链式风格差异
java·开发语言