06Ribbon学习

负载均衡:将负载分摊到多个执行单元上,常见的负载均衡方式有两种。

第一种是独立进程单元,通过负载均衡策略,将请求转发到不同的执行单元上;

第二种是将负载均衡逻辑以代码的形式封装到服务消费者的客户端上,服务消费者客户端维护一份服务提供者的信息列表,消费者通过负载均衡策略将请求分摊到多个服务提供者,以达到负载均衡的目的。

源码解析Ribbon

第一部分获取提供者服务信息,通过ILoadBalancer获取服务提供者信息

LoadBalancerClient.. choose(ServiceId)

       RibbonLoadBalancerClient. choose(String serviceId)

              RibbonLoadBalancerClient .getServer(ILoadBalancer loadBalancer)

 

第二部分IloadBalancer解析

ILoadBalancer的体系结构

 

BaseLoadBalancer属性说明

IClientConfig:用于配置负载均衡的客户端

IRule:用于配置负载均衡的策略

IPing:用于判断Server是否有响应

ServerList:所有Server的注册列表信息

 

DynamicServerListLoadBalancer继承BaseLoadBalancer具有以上所有属性

在接口第一次调用的时候

DynamicServerListLoadBalancer.initWithNiwsConfig(IClientConfig clientConfig)

       DynamicServerListLoadBalancer.restOfInit(IClientConfig clientConfig)

              DynamicServerListLoadBalancer.updateListOfServers()

                     DiscoveryEnabledNIWSServerList.getUpdatedListOfServers()

                            DiscoveryEnabledNIWSServerList.obtainServersViaDiscovery()

经过以上步骤,最后通过eurekaClient将服务信息InstanceInfo保存到serverList中

 

第三部分从Eureka Client获取信息更新到LoadBalancer的过程

由于服务的列表是动态更新的,实现负载均衡的模块需要定时刷新维护的服务列表信息

BaseLoadBalancer. setupPingTask()

       new PingTask()

              runPinger()

在初始化的时候创建定时任务获取服务注册列表信息,通过ping来判断服务是否可用,当服务发生改变,则重新拉取服务列表信息

 

第四部分LoadBalancer实现负载均衡

LoadBalancerAutoConfiguration维护着一个RestTemplate的列表引用,当服务启动的时候,通过迭代restTemplate将拦截器注入RestTemplate中,实现拦截请求处理,而拦截器中实现了负载均衡算法

内容来自《深入理解Spring Cloud与微服务构建》

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值