Ribbon源码解析

原文:https://blog.youkuaiyun.com/forezp/article/details/74820899

重要组件

ServiceInstanceChooser接口,根据serviceId来获取serviceInstance

ServiceInstanceChooser实现接口LoadBalancerClient接口它作为负载均衡的一个客户端,执行请求,重构url

LoadBalancerClient实现类RibbonLoadBalancerClient: 负载均衡的请求处理

RibbonLoadBalancerClient方法中交给 ILoadBalancer接口选择服务实例

ILoadBalancer接口实现类BaseLoadBalancer: 里面有路由策略,负载均衡配置类,构造函数开启了一个PingTask任务

                                                                            默认向服务端10s ping一次

BaseLoadBalancer里面引用IRule接口: 他的实现类里面有各种路由策略,最小请求数,轮询,随机

Iping接口是用来想调用server发生"ping"的,来判断server是否可用.

由此可见,负载均衡器是从EurekaClient获取服务信息,并根据IRule去路由,并且根据IPing去判断服务的可用性。

RestTemplate是如何和Ribbon结合的

  加一个@LoadBalanced注解,LoadBalanced自动配置类中,增加了一个LoadBalancerInterceptor拦截器

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值