微服务篇之负载均衡

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

相关推荐
于先生吖6 分钟前
支持二开与商用,JAVA 漫剧付费观看系统完整源码
java·开发语言
曹牧9 分钟前
Java: 从oracle表中获取一组kv序列
java·开发语言·oracle
Lyyaoo.10 分钟前
【Java基础面经】Java 注解的底层原理
java·开发语言·python
妙蛙种子31111 分钟前
【Java设计模式 | 创建者模式】 抽象工厂模式
java·开发语言·后端·设计模式·抽象工厂模式
C'ᴇsᴛ.小琳 ℡12 分钟前
App架构的演化
架构
程序员小郭8313 分钟前
MySQL分库分表策略全解析(实战版)
数据库·mysql·架构
雄哥00715 分钟前
spring 升级记录
java·后端·spring·spring升级
卓怡学长15 分钟前
m320基于Java的网络音乐系统的设计与实现
java·数据库·spring·tomcat·maven
yaaakaaang16 分钟前
五、原型模式
java·原型模式
chh56320 分钟前
从零开始学C++--类和对象
java·开发语言·c++·学习·算法