微服务篇之负载均衡

一、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. 在客户端的配置文件中,可以配置某一个服务调用的负载均衡策略,只是对配置的这个服务生效远程调用。

相关推荐
Moe4881 分钟前
Java 反射机制
java·后端·架构
丶小鱼丶2 分钟前
数据结构和算法之【链表】
java·数据结构·算法
Sun 32852 分钟前
MyBatis-Plus 新版代码生成器的使用
java·spring boot·后端·spring·配置·mybatis-plus·代码生成器
一直都在5724 分钟前
新Java基础(二十五):异常类
java·开发语言
礼拜天没时间.4 分钟前
力扣热题100实战 | 第31期:下一个排列——数组规律的极致探索
java·算法·leetcode·字典序·原地算法·力扣热题100
xiaoye37089 分钟前
java后端面试一般问什么?
java·面试
UrbanJazzerati9 分钟前
从“加载中”到完整下载:破解PDF异步加载与反爬的完整指南
后端·面试
数据中穿行11 分钟前
基于MBSE的DoDAF能力视点完整案例
架构
badhope11 分钟前
OpenClaw卸载命令全解析
java·linux·人工智能·python·sql·数据挖掘·策略模式
兆子龙12 分钟前
Raft 共识算法与 etcd 实践:从选主到日志复制的完整链路
后端·架构