负载均衡器对外提供负载均衡的功能,本质上是是维护当前服务的服务器列表和服务器状态,通过负载均衡算法选取合适的服务器地址。

  用户可以通过实现ILoadBalancer来实现自己的负载均衡器,ribbon也提供了BaseLoadBalancer、DynamicServerListLoadBalancer、ZoneAwareLoadBalancer三个负载均衡器。

ILoadBalancer

  负载均衡器接口,定义了负载均衡器的相关方法。

public interface ILoadBalancer {
/**
* 向负载均衡器添加服务器实体。
*
* @param newServers new servers to add
*/
public void addServers(List<Server> newServers);
/**
* 选择一台Server*/
public Server chooseServer(Object key);
/**
* 将指定Server标记为down
*
* @param server Server to mark as down
*/
public void markServerDown(Server server);/**
* 返回所有启动的服务。*/
public List<Server> getReachableServers();
/**
* 返回所有的服务。*/
public List<Server> getAllServers();
}

BaseLoadBalancer

  ribbon实现的基本负载均衡器。本质上BaseLoadBalancer内部维护了当前服务器的服务器列表,BaseLoadBalancer不会自动更新服务器列表。

  ribbon会定时去检查服务器列表中服务器的存活情况,内部会启动一个定时器,使用IPing来对服务器状态进行检测,使用IPingStrategy来定义检测策略,然后更新upServerList,并调用相应的监听器。通过实现IPing接口来实现单台服务器探测流程,ribbon默认提供了DummyPing实现;使用IPingStrategy来定义检测服务器列表策略,ribbon默认提供了SerialPingStrategy,通过序列化方式探测服务器列表。BaseLoadBalancer会启动线程定时执行服务器探测,当IPing实现为DummyPing时,不会启动探测流程。

  ribbon使用IRule来进行服务器路由,用户可以通过实现IRule来定义路由策略,ribbon也提供了一些路由算法( ribbon源码之负载均衡算法)。

  有很多负载均衡算法需要依据服务器的执行状态进行路由,ribbon使用了LoadBalancerStats来存储服务器列表中每个服务器的运行状态(ribbon源码(4) 服务器状态)。LoadBalancerStats不会自动收集服务器状态,需要在执行服务器调用过程时更新LoadBalancerStats中的状态。

  使用ServerListChangeListener来提供用户监听服务器列表变化。使用ServerStatusChangeListener来提供用户监听服务器状态变化。内部也会启动定时器来定时监听所有服务器的存活状态。使用IClientConfig来读取配置信息。

DynamicServerListLoadBalancer

  可以自动动态更新server的负载均衡器,继承BaseLoadBalancer。本质上就是定义了一个定时器,定时执行拉取服务器列表和更新负载均衡器服务器列表。用户可以通过实现ServerListUpdater接口来实现定时器功能;通过实现ServerList接口实现拉去服务器功能;通过实现ServerListFilter接口实现过滤服务器功能。ConfigurationBasedServerList是ribbon提供的一个服务器列表源类,从配置文件中获取服务器列表;PollingServerListUpdater是ribbon提供的一个定时执行类,内部通过ScheduledThreadPoolExecutor实现定时执行。ZoneAffinityServerListFilter过滤掉与客户端不在同一可用区中的服务,除非同一区中没有可用服务,如果当前zone的请求量、熔断比率、服务器存活比如高于指定指标,就不过滤;否则过滤其他的zone。ServerListSubsetFilter该过滤器确保客户端只能看见所有服务列表中的一个固定子集,它也可以周期性的用新服务替换掉子集中低可用的服务,当服务有大量服务器时非常有用,可以减少网络链接。

ZoneAwareLoadBalancer

  ZoneAwareLoadBalancer以zone为单位,过滤调那些性能不达标的zone,然后从剩下中随机选择一个zone,当选择了zone后再在这个zone中根据设定rule进行路由选择。

ribbon源码(2) 负载均衡器的更多相关文章

  1. ribbon源码(1) 概述

    ribbon的核心功能是提供客户端在进行网络请求时负载均衡的能力.主要有以下几个模块: 负载均衡器模块 负载均衡器模块提供了负载均衡能力,详细参见ribbon源码之负载均衡器. 配置模块 配置模块管理 ...

  2. 【一起学源码-微服务】Ribbon源码五:Ribbon源码解读汇总篇~

    前言 想说的话 [一起学源码-微服务-Ribbon]专栏到这里就已经全部结束了,共更新四篇文章. Ribbon比较小巧,这里是直接 读的spring cloud 内嵌封装的版本,里面的各种config ...

  3. Ribbon源码分析(二)-- 服务列表的获取和负载均衡算法分析

    上一篇博客(https://www.cnblogs.com/yangxiaohui227/p/12614343.html)分享了ribbon如何实现对http://product/info/这个链接重 ...

  4. 读书笔记-Ribbon源码分析

    @LoadBalanced注解用来给RestTemplate做标记,以使用负载均衡的客户端来配置. 通过搜索LoadBalancerClient可以发现,LoadBalancerClient是Spri ...

  5. Spring Cloud Ribbon 源码分析---负载均衡算法

    上一篇分析了Ribbon如何发送出去一个自带负载均衡效果的HTTP请求,本节就重点分析各个算法都是如何实现. 负载均衡整体是从IRule进去的: public interface IRule{ /* ...

  6. ribbon源码分析

    对于ribbon的使用我们只需要在RestTemplate的申明上面加上 @LoadBalanced 注解之后那么这个RestTemplate就具有了负载均衡的功能 ribbon是怎么实现这一功能的? ...

  7. 超详细的Ribbon源码解析

    Ribbon简介 什么是Ribbon? Ribbon是springcloud下的客户端负载均衡器,消费者在通过服务别名调用服务时,需要通过Ribbon做负载均衡获取实际的服务调用地址,然后通过http ...

  8. Netflix Ribbon源码设计错误的证据(附正确示例)

    我在之前一篇博客里https://www.cnblogs.com/yangfeiORfeiyang/p/9644254.html 里对Netflix Ribbon的Loadbalancer类源码设计的 ...

  9. 【一起学源码-微服务】Ribbon 源码一:Ribbon概念理解及Demo调试

    前言 前情回顾 前面文章已经梳理清楚了Eureka相关的概念及源码,接下来开始研究下Ribbon的实现原理. 我们都知道Ribbon在spring cloud中担当负载均衡的角色, 当两个Eureka ...

随机推荐

  1. utf-8变长

    utf-8变长 变长规则 一字节:0******* 两字节:110,10* 三字节:1110,10,10**** 四字节:11110**,10******,10,10* 如果是以0开头的,那么他就是一 ...

  2. 「查缺补漏」巩固你的RocketMQ知识体系

    Windows安装部署 下载 地址:[https://www.apache.org/dyn/closer.cgi?path=rocketmq/4.5.2/rocketmq-all-4.5.2-bin- ...

  3. 极简 Node.js 入门 - 3.2 文件读取

    极简 Node.js 入门系列教程:https://www.yuque.com/sunluyong/node 本文更佳阅读体验:https://www.yuque.com/sunluyong/node ...

  4. JavaScript学习系列博客_31_JavaScript Math 工具类

    Math - Math属于一个工具类,它不需要我们创建对象(例如Date日期对象需要通过构造函数创建对象 var 变量=new Date(),Math不需要),它里边封装了属性运算相关的常量和方法 我 ...

  5. 第2章 RDD编程(2.3)

    第2章 RDD编程(2.3) 2.3 TransFormation 基本RDD Pair类型RDD (伪集合操作  交.并.补.笛卡尔积都支持) 2.3.1 map(func) 返回一个新的RDD,该 ...

  6. golang学习笔记:Interface类型断言详情

    原文链接:https://www.2cto.com/kf/201712/703563.html 1. 用于判断变量类型 demo如下: switch t := var.(type){ case str ...

  7. Tensorflow2(二)tf.data输入模块

    代码和其他资料在 github 一.tf.data模块 数据分割 import tensorflow as tf dataset = tf.data.Dataset.from_tensor_slice ...

  8. 大白话带你认识 ZooKeeper !重要概念一网打尽!

    大家好,我是 「后端技术进阶」 作者,一个热爱技术的少年. 1. 前言 相信大家对 ZooKeeper 应该不算陌生.但是你真的了解 ZooKeeper 到底有啥用不?如果别人/面试官让你给他讲讲对于 ...

  9. CSS 选择器及优先级

    CSS 选择器及优先级 1.根据权值计算 div .class1 #people的权值等于1+10+100=111 .class2 li #age的权值等于10+1+100=111 2.权值相同,那么 ...

  10. 从零开始的SpringBoot项目 ( 三 ) 项目打包( jar包篇 )

    一.准备工作 1.工具:Idea , maven 2.首先得保证 pom 有 maven 插件 二.开始打包 找到最右边的Maven Projects,点击进去,选择需要打包的项目,并点击 insta ...