Spring Cloud 五大核心组件解析之Ribbon组件IRule详解(下)

本文涉及的产品
全局流量管理 GTM,标准版 1个月
云解析 DNS,旗舰版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
简介: Spring Cloud 五大核心组件解析之Ribbon组件IRule详解(下)

前言:上篇文章介绍了IRule的几种负载策略,还剩下几种,本章将会进行讲解。


往期回顾

Spring Cloud 五大核心组件解析之Ribbon组件IRule详解(上)


7.WeightedResponseTimeRule
介绍:

WeightedResponseTimeRule这个策略每30秒计算一次服务器响应时间,以响应时间作为权重,响应时间越短的服务器被选中的概率越大。
工作原理:

WeightedResponseTimeRule很有意思,它默认起了一个循环的定时任务,时间是30S,每30S就调度一次任务DynamicServerWeightTaskDynamicServerWeightTask的关键方法是run(),在run()中调用了serverWeight.maintainWeights(),maintainWeights()的作用是计算出每个服务器的响应时间,用来给choose()选择服务器。

8.ZoneAvoidanceRule
介绍:

ZoneAvoidanceRulePredicateBasedRule的一个实现类,但是比PredicateBasedRule多了一个过滤条件。
工作原理:

ZoneAvoidanceRule中的过滤条件是以ZoneAvoidancePredicate为主过滤条件和以AvailabilityPredicate为次过滤条件组成的一个叫做CompositePredicate的组合过滤条件,过滤成功之后,继续采用线性轮询的方式从过滤结果中选择一个出来。
注意:不论是主过滤条件还是次过滤条件,都需要判断下面两个条件,只要有一个条件符合,就不再过滤,将当前结果返回供线性轮询。1)过滤后的实例总数>=最小过滤实例数(默认为1)2)过滤的实例比例>最小过滤百分比(默认为0)

9.AvailabilityFilteringRule

介绍:

AvailabilityFilteringRule策略继承自抽象策略PredicateBasedRule,所以也继承了"先过滤清单,再轮询选择"的基本处理逻辑了"先过滤清单,再轮询选择"的基本处理逻辑。该策略通过线性抽样的方式直接尝试可用且较空闲的实例来使用,优化了父类每次都要遍历所有实例的开销。

工作原理:

AvailabilityFilteringRule的过滤条件中有一个AvailabilityPredicate的过滤条件,这个条件用于判断两个条件1)断路器是否生效已打开,满足该条件,过滤掉。2)实例的并发请求数大于阈值。大约阈值,过滤掉。过滤成功之后,继续采用线性轮询的方式从过滤结果中选择一个出来。

下期预告:

IRule我们在这里就讲完了,大家有兴趣的可以去多看看源码,源码的代码风格以及编程思想才是我们应该学习的。下期我们将会讲解IPing的原理知识,不用枯燥的代码就让你了解深入的知识。


相关文章
|
2月前
|
监控 Java 应用服务中间件
高级java面试---spring.factories文件的解析源码API机制
【11月更文挑战第20天】Spring Boot是一个用于快速构建基于Spring框架的应用程序的开源框架。它通过自动配置、起步依赖和内嵌服务器等特性,极大地简化了Spring应用的开发和部署过程。本文将深入探讨Spring Boot的背景历史、业务场景、功能点以及底层原理,并通过Java代码手写模拟Spring Boot的启动过程,特别是spring.factories文件的解析源码API机制。
107 2
|
25天前
|
存储 SpringCloudAlibaba Java
【SpringCloud Alibaba系列】一文全面解析Zookeeper安装、常用命令、JavaAPI操作、Watch事件监听、分布式锁、集群搭建、核心理论
一文全面解析Zookeeper安装、常用命令、JavaAPI操作、Watch事件监听、分布式锁、集群搭建、核心理论。
【SpringCloud Alibaba系列】一文全面解析Zookeeper安装、常用命令、JavaAPI操作、Watch事件监听、分布式锁、集群搭建、核心理论
|
25天前
|
设计模式 XML Java
【23种设计模式·全精解析 | 自定义Spring框架篇】Spring核心源码分析+自定义Spring的IOC功能,依赖注入功能
本文详细介绍了Spring框架的核心功能,并通过手写自定义Spring框架的方式,深入理解了Spring的IOC(控制反转)和DI(依赖注入)功能,并且学会实际运用设计模式到真实开发中。
【23种设计模式·全精解析 | 自定义Spring框架篇】Spring核心源码分析+自定义Spring的IOC功能,依赖注入功能
|
2月前
|
XML Java 数据库连接
Spring高手之路25——深入解析事务管理的切面本质
本篇文章将带你深入解析Spring事务管理的切面本质,通过AOP手动实现 @Transactional 基本功能,并探讨PlatformTransactionManager的设计和事务拦截器TransactionInterceptor的工作原理,结合时序图详细展示事务管理流程,最后引导分析 @Transactional 的代理机制源码,帮助你全面掌握Spring事务管理。
43 2
Spring高手之路25——深入解析事务管理的切面本质
|
2月前
|
Java 开发者 Spring
深入解析:Spring AOP的底层实现机制
在现代软件开发中,Spring框架的AOP(面向切面编程)功能因其能够有效分离横切关注点(如日志记录、事务管理等)而备受青睐。本文将深入探讨Spring AOP的底层原理,揭示其如何通过动态代理技术实现方法的增强。
90 8
|
2月前
|
前端开发 Java 开发者
Spring MVC中的请求映射:@RequestMapping注解深度解析
在Spring MVC框架中,`@RequestMapping`注解是实现请求映射的关键,它将HTTP请求映射到相应的处理器方法上。本文将深入探讨`@RequestMapping`注解的工作原理、使用方法以及最佳实践,为开发者提供一份详尽的技术干货。
174 2
|
2月前
|
前端开发 Java Spring
探索Spring MVC:@Controller注解的全面解析
在Spring MVC框架中,`@Controller`注解是构建Web应用程序的基石之一。它不仅简化了控制器的定义,还提供了一种优雅的方式来处理HTTP请求。本文将全面解析`@Controller`注解,包括其定义、用法、以及在Spring MVC中的作用。
69 2
|
2月前
|
前端开发 Java Maven
深入解析:如何用 Spring Boot 实现分页和排序
深入解析:如何用 Spring Boot 实现分页和排序
95 2
|
2月前
|
Java 开发者 Spring
Spring AOP深度解析:探秘动态代理与增强逻辑
Spring框架中的AOP(Aspect-Oriented Programming,面向切面编程)功能为开发者提供了一种强大的工具,用以将横切关注点(如日志、事务管理等)与业务逻辑分离。本文将深入探讨Spring AOP的底层原理,包括动态代理机制和增强逻辑的实现。
56 4
|
1月前
|
负载均衡 Java Nacos
常见的Ribbon/Spring LoadBalancer的负载均衡策略
自SpringCloud 2020版起,Ribbon被弃用,转而使用Spring Cloud LoadBalancer。Ribbon支持轮询、随机、加权响应时间和重试等负载均衡策略;而Spring Cloud LoadBalancer则提供轮询、随机及Nacos负载均衡策略,基于Reactor实现,更高效灵活。
122 0

热门文章

最新文章

推荐镜像

更多