Spring Cloud Ribbon源码分析(二) 列表更新

简介: Spring Cloud Ribbon源码分析(二) 列表更新

image.png


上节回顾:

通过Ribbon集成之后,RestTemplate做了什么事情?RestTemplate本身是一个HTTP客户端,让我们更加简化的完成HTTP请求,但是因为集成Ribbon后需要对请求实现负载均衡,所以在RestTemplate真正发起HTTP请求之前做了一个拦截,这个拦截就是LoadBalancerInterceptor完成的,它的最终实现是RibbonLoadBlancerClient去进行拦截和处理,在拦截过程中分析了几个阶段,第一个阶段是初始化阶段,怎么对加了LoadBalancer的注解RestTemplate进行拦截,通过讲解了自动装配过程,讲到LoadBalancerAutoConfiguration自动装配类,这个装配类里边是嵌套的Bean的依赖,下图的顺序就是bean的初始化的过程。通过这个一个过程对RestTemplate加了一个拦截,就可以使用负载均衡处理。


image.png


image.png


负载均衡规则:

RoundRobbinRule:默认的轮询规则

WeightedResponseTimeRule:通过服务平均的响应时间,给每一个服务一个权重,响应时间越长,权重越小,开始统计信息不足,应用轮序策略。

RandonRule:随机获取一个服务

RetryRule:先按照轮询策略获取服务如果获取服务失败则在指定时间内会重试,获取可用的服务。


image.png


allServerList和upServerList,服务器端提供地址列表在客户端内存中的缓存


image.png


调用规则


1,我们构建ZoneAwareLoadBalancer的其父类方法DynamicServerListLoadBalancer中的构造方法会执行,会调用this.restOfInit(clientConfig);


2,restOfInit中有两个重要的方法,enableAndInitLearnNewServersFeature和updateListOfServers;


3,enableAndInitLearnNewServersFeature调用,总体思想是用定时器scheduled通过updateListOfServers()来更新Eurake实例列表,enableAndInitLearnNewServersFeature中this.serverListUpdater.start(this.updateAction)默认每30s执行一次更新本地服务器列表,run中定时器,updateAction中调用了updateListOfServers方法。

serverListUpdater.start是在RibbonClientConfiguration中初始化的。


4,updateListOfServers调用serverListImpl.getUpdatedListOfServers()来更新服务器列表,getUpdatedListOfServers可以有多个实现,可以从本地配置文件获取,也可以从Eurake列表获取;


5,updateListOfServers中调用updateAllServerList,updateAllServerList调用setServersList,setServersList调用父类BaseLoadBalancersetServersList方法,更新BaseLoadBalancer中allserverList和upserverList列表


6,ping确认存活策略,DynamicServerListLoadBalancer的父类BaseLoadBalancer的构造方法中会设置this.initWithConfig();,this.initWithConfig会调用


this.setPingInterval(pingIntervalTime)不断去检查,将无法连接的节点去除掉。定时器也是通过scheduled。


相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
目录
相关文章
|
监控 Java 应用服务中间件
Spring Boot整合Tomcat底层源码分析
【11月更文挑战第20天】Spring Boot是一个用于快速构建基于Spring框架的应用程序的开源框架。它通过自动配置和起步依赖等特性,大大简化了Spring应用的开发和部署过程。本文将深入探讨Spring Boot的背景历史、业务场景、功能点以及底层原理,并通过Java代码手写模拟Spring Boot的启动过程,特别是其与Tomcat的整合。
466 1
|
负载均衡 算法 Java
除了 Ribbon,Spring Cloud 中还有哪些负载均衡组件?
这些负载均衡组件各有特点,在不同的场景和需求下,可以根据项目的具体情况选择合适的负载均衡组件来实现高效、稳定的服务调用。
1478 61
|
资源调度 Java 调度
Spring Cloud Alibaba 集成分布式定时任务调度功能
Spring Cloud Alibaba 发布了 Scheduling 任务调度模块 [#3732]提供了一套开源、轻量级、高可用的定时任务解决方案,帮助您快速开发微服务体系下的分布式定时任务。
16592 123
|
设计模式 XML Java
【23种设计模式·全精解析 | 自定义Spring框架篇】Spring核心源码分析+自定义Spring的IOC功能,依赖注入功能
本文详细介绍了Spring框架的核心功能,并通过手写自定义Spring框架的方式,深入理解了Spring的IOC(控制反转)和DI(依赖注入)功能,并且学会实际运用设计模式到真实开发中。
【23种设计模式·全精解析 | 自定义Spring框架篇】Spring核心源码分析+自定义Spring的IOC功能,依赖注入功能
|
监控 Java 应用服务中间件
SpringBoot是如何简化Spring开发的,以及SpringBoot的特性以及源码分析
Spring Boot 通过简化配置、自动配置和嵌入式服务器等特性,大大简化了 Spring 应用的开发过程。它通过提供一系列 `starter` 依赖和开箱即用的默认配置,使开发者能够更专注于业务逻辑而非繁琐的配置。Spring Boot 的自动配置机制和强大的 Actuator 功能进一步提升了开发效率和应用的可维护性。通过对其源码的分析,可以更深入地理解其内部工作机制,从而更好地利用其特性进行开发。
627 6
|
消息中间件 监控 Java
如何将Spring Boot + RabbitMQ应用程序部署到Pivotal Cloud Foundry (PCF)
如何将Spring Boot + RabbitMQ应用程序部署到Pivotal Cloud Foundry (PCF)
438 6
|
缓存 JavaScript Java
Spring之FactoryBean的处理底层源码分析
本文介绍了Spring框架中FactoryBean的重要作用及其使用方法。通过一个简单的示例展示了如何通过FactoryBean返回一个User对象,并解释了在调用`getBean()`方法时,传入名称前添加`&`符号会改变返回对象类型的原因。进一步深入源码分析,详细说明了`getBean()`方法内部对FactoryBean的处理逻辑,解释了为何添加`&`符号会导致不同的行为。最后,通过具体代码片段展示了这一过程的关键步骤。
253 1
Spring之FactoryBean的处理底层源码分析
|
Java 关系型数据库 MySQL
如何将Spring Boot + MySQL应用程序部署到Pivotal Cloud Foundry (PCF)
如何将Spring Boot + MySQL应用程序部署到Pivotal Cloud Foundry (PCF)
361 5
|
缓存 监控 Java
如何将Spring Boot应用程序部署到Pivotal Cloud Foundry (PCF)
如何将Spring Boot应用程序部署到Pivotal Cloud Foundry (PCF)
389 5
|
前端开发 Java Spring
Spring MVC源码分析之DispatcherServlet#getHandlerAdapter方法
`DispatcherServlet`的 `getHandlerAdapter`方法是Spring MVC处理请求的核心部分之一。它通过遍历预定义的 `HandlerAdapter`列表,找到适用于当前处理器的适配器,并调用适配器执行具体的处理逻辑。理解这个方法有助于深入了解Spring MVC的工作机制和扩展点。
219 1

热门文章

最新文章