负载均衡:将负载分摊到多个执行单元上,常见的负载均衡方式有两种。
第一种是独立进程单元,通过负载均衡策略,将请求转发到不同的执行单元上;
第二种是将负载均衡逻辑以代码的形式封装到服务消费者的客户端上,服务消费者客户端维护一份服务提供者的信息列表,消费者通过负载均衡策略将请求分摊到多个服务提供者,以达到负载均衡的目的。
源码解析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与微服务构建》