spring cloud ribbon 负载均衡类1

Ribbon 在实现客户端负载均衡时,是通过Ribbo的ILoadBalancer接口实现的。

AbstractLoadBalancer

是ILoadBalancer接口的抽象实现,定义了一个分组枚举类ServerGroup

还实现了一个chooseServer()方法,其中key为null,表示在选择具体实例时忽略key的条件判断

还定义了两个抽象方法

    getServerList(ServerGroup serverGroup):根据分组类型获取不同的实例列表

    getLoadBalancerStats():定义了获取LoadBalancerStats对象的方法,

LoadBalancerStats对象被用来存储负载均衡中各个服务实例当前的属性和统计信息。

BaseLoadBalancer

是Ribbon负载均衡的基础实现类,

  定义并维护了两个存储服务实例Server对象的列表。一个用于存储所有服务实例的清单,

一个用于存储正常服务的实例清单

  定义了各服务实例属性和统计信息的LoadBalancerStats对象

  定义了检查服务实例是否正常服务的IPing对象,默认为null,构造时注入

  定义了检查服务实例操作的执行策略对象IPingStrategy,在BaseLoadBalancer中

默认使用了SerialPingStrategy,遍历检查

  定义了负载均衡的处理规则IRule对象,从BaseLoadBalancer中

chooseServer(Object key),实际将选择任务委托给IRule.choose()方法,IRule默认为

RoundRobinRule

  启动ping任务:在BaseLoadBalancer的默认构造方法中,会直接启动一个用于定时检查Server是否健康的任务

  DynamicServerListLoadBalancer<T>

对基础负载均衡的扩展。在该负载均衡中,实现了服务实例清单在运行期的动态更新能力;

同时,还具备了对服务实例清单的过滤功能。新增如下

  ServerList<T> serverListImpl

ServerList继承结构如下

上图中有多个ServerList的实现类,那么在DynamiceServerListLoadBalancer中的ServerList默认配置到底使用了哪个具体实现?

既然该负载均衡类中需要实现服务实例的动态更新,那么势必需要Ribbon具备访问Eureka来获取服务实例的能力,在包

org.springframework.cloud.netflix.ribbon.eureka下,可以找到配置类EurekaRibbonClientConfiguration,找到如下

这里创建的一个DomainExtractingServerList实例,在这个类源码中,还定义类一个ServerList list. 同时对getInitialListOfServers()

和getUpdatedListOfServers()的具体实现,其实委托给内部定义的ServerList list对象

由构造方法传入的DiscoveryEnabledNIWSServerLIst实现的。

在DiscoveryEnableNIWSServerList中

在obtainServersViaDiscovery()方法中

主要逻辑是,依靠EurekaClient从服务注册中心获取到具体的服务实例InstanceInfo列表,vipAddress可以理解为逻辑上的服务名如USER-SERVICE

然后遍历,找到UP的实例转换成DiscoveryEnabledServer对象 ,返回

返回的结果List到了DomainExtractingServerList类中,将继续通过setZones()方法进行处理

  ServerListUpdater

  DynamicServerListLoadBalancer类中属性ServerListUpdater中

主要是对ServerList的更新,

而ServerListUpdater的实现类不多,如下

PollingServerListUpdater:动态服务列表更新的默认策略,也就是DynamicServerListLoadBalancer中默认实现,

它通过定时任务实现更新

 EurekaNotificationServerListUpdater 需要利用Eureka的事件监听器来驱动服务列表的更新操作

ServerListFilter

回到updateAction.doUpdate()方法,在DynamicServerListLoadBalancer中,调用updateListOfServers()方法

调用之前提到的ServerList.getUpdatedListOfServers(),获取到从Eureka Server中获取服务可用实例的列表。

通过ServerListFilter filter过滤,继承关系如下

  AbstractServerListFilter:定义类过滤时需要的一个重要对象LoadBalancerStats,该对象存储了一些属性和统计信息等

ZoneAffinityServerListFilter:该过滤器基于“区域感知(Zone Affinity)”的方式实现服务实例的过滤,源码

过滤后,通过shouldEnableZoneAffinity()方法来判断是否启用“区域感知”功能。

使用LoadBalancerStats.getZoneSnapshot()获取过滤后同区域实例的基础指标(包含实例数量,断路器断开数,活动请求数,实例平均负载等)

根据一系列的算法求出下面的几个评价值并与设置的阈值进行比较,若有一个条件符合,就不启用“区域感知”。

可以实现当集群出现区域故障时,依然可以依靠其他区域的实例进行正常服务的高可用保障。

  blackOutServerPercentage:故障实例百分比(断路器断开数/实例数)>=0.8

activeRequestsPerServer:实例平均负载>=0.6

availableSevers: 可用实例数(实例数 - 断路器断开数)<2

DefaultNIWSServerListFilter 完全继承ZoneAffinityServerListFilter,是默认NIWS(Netflix Internal Web Server)过滤器

ServerListSubSetFilter:
ZonePreferenceServerListFilter: Spring Cloud整合时新增的过滤器。若使用Spring Cloud整合Eureka和Ribbon时默认使用该过滤器

根据zone过滤出实例

原文地址:https://www.cnblogs.com/toUpdating/p/9343034.html

时间: 2024-08-05 04:52:30

spring cloud ribbon 负载均衡类1的相关文章

spring cloud 客户端负载均衡 - Ribbon

Spring Cloud Ribbon是一个基于HTTP和TCP的客户端负载均衡工具,基于Netflix Ribbon实现的,Ribbon不像注册中心.网关那样需要单独部署,它是作为一个工具直接集成到Service里.后面要讲到的Feign里面也集成了Ribbon. 1.手动搭建一个客户端负载均衡 准备工作: 准备一个由 peer1.peer2 构成的配置中心 准备一个由 service-1(8091).service-1(8092) 构成的服务端集群 准备一个Ribbon客户端 添加pom依赖

客户端负载均衡Ribbon之一:Spring Cloud Netflix负载均衡组件Ribbon介绍

Netflix:['netfli?ks] ribbon:英[?r?b?n]美[?r?b?n]n. 带; 绶带; (打印机的) 色带; 带状物;v. 把…撕成条带; 用缎带装饰; 形成带状;     LB方案分类 目前主流的LB方案可分成两类: 一种是集中式LB, 即在服务的消费方和提供方之间使用独立的LB设施(可以是硬件,如F5, 也可以是软件,如nginx), 由该设施负责把访问请求通过某种策略转发至服务的提供方: 另一种是进程内LB,将LB逻辑集成到消费方,消费方从服务注册中心获知有哪些地址

Spring Cloud Netflix负载均衡组件Ribbon介绍

Netflix:['netfli?ks] ribbon:英[?r?b?n]美[?r?b?n]n. 带; 绶带; (打印机的) 色带; 带状物;v. 把…撕成条带; 用缎带装饰; 形成带状;     LB方案分类 目前主流的LB方案可分成两类: 一种是集中式LB, 即在服务的消费方和提供方之间使用独立的LB设施(可以是硬件,如F5, 也可以是软件,如nginx), 由该设施负责把访问请求通过某种策略转发至服务的提供方: 另一种是进程内LB,将LB逻辑集成到消费方,消费方从服务注册中心获知有哪些地址

spring boot分布式技术,spring cloud,负载均衡,配置管理器

spring boot分布式的实现,使用spring cloud技术. 下边是我理解的spring cloud的核心技术: 1.配置服务器 2.注册发现服务器eureka(spring boot默认使用的服务器类别) 3.RestTemplate通过ribbon实现负载均衡技术 具体请看下列图: 参考:http://www.cnblogs.com/skyblog/p/5127690.html

Spring Cloud做负载均衡

1.新建maven工程,点击finish完成     2.在pom.xml文件中加入必要的依赖 <?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLoca

Spring Cloud Ribbon

Spring Cloud Ribbon:负载均衡的服务调用 前言 什么是Ribbon? Spring Cloud Ribbon是一套实现客户端负载均衡的工具,注意是客户端,当然也有服务端的负载均衡工具,如Ngnix,可以认为Ribbon就是一个负载均衡(Load Balancer).负载均衡就是将用户的请求平摊的分配到多个服务器,从而达到系统的高可用. 简单来说,Ribbon的主要功能是提供客户端的软件负载均衡算法,将Netflix的中间层服务连接在一起. 在微服务架构中,很多服务都会部署多个,

笔记:Spring Cloud Ribbon 客户端负载均衡

Spring Cloud Ribbon 是一个基于 HTTP 和 TCP 的客户端负载均衡工具,基于 Netflix Ribbon 实现,通过Spring Cloud 的封装,可以让我们轻松的将面向服务的REST 模板请求自动转换为客户端负载均衡的服务调用.客户端负载均衡在系统架构中是一个非常重要的,并且是不得不去实施的内容,因为负载均衡是对系统的高可用.网络压力的缓解和处理能力扩容的重要手段,客户端负载均衡需要通过心跳去维护服务端清单的健康性,这个需要服务注册中心配合完成,在Spring Cl

撸一撸Spring Cloud Ribbon的原理-负载均衡策略

在前两篇<撸一撸Spring Cloud Ribbon的原理>,<撸一撸Spring Cloud Ribbon的原理-负载均衡器>中,整理了Ribbon如何通过负载均衡拦截器植入RestTemplate,以及调用负载均衡器获取服务列表,如何过滤,如何更新等的处理过程. 因为,负载均衡器最终是调用负载均衡策略的choose方法来选择一个服务,所以这一篇,整理Ribbon的负载均衡策略. 策略类 RandomRule RoundRobinRule RetryRule WeightedR

第四章 客户端负载均衡:Spring Cloud Ribbon

Spring Cloud R巾bon 是一个基于 HTTP 和 TCP 的客户端负载均衡工具,它基于 NetflixRibbon 实现. 通过 Spring Cloud 的封装, 可以让我们轻松地将面向服务的 REST 模板请求自动转换成客户端负载均衡的服务调用 客户端负载均衡 我们通常所说的负载均衡都指的是服务端负载均衡, 其中分为硬件负载均衡和软件负载均衡. 硬件负载均衡主要通过在服务器节点之间安装专门用于负载均衡的设备,比如 F5 等:而软件负载均衡则是通过在服务器上安装一些具有均衡负载功