Spring Cloud 2.2.2 源码之十四Ribbon初始化一
初始化主要结构图

LoadBalancerAutoConfiguration
还是自动配置的约定,里面有个LoadBalancerAutoConfiguration类。

注入RestTemplate实例集合
注入所有的RestTemplate实例,但是是有条件的,需要有LoadBalanced注解的,为什么突然有这个要求,我们后面讲。

LoadBalancerInterceptor拦截器
实现负载均衡,用的是拦截器,在请求之前把服务名根据负载均衡算法替换成相应的服务实例地址,然后就去请求。

LoadBalancerRequestFactory请求工厂
LoadBalancerRequestFactory,用来拦截后重新创建请求。

RestTemplateCustomizer定制化器
将LoadBalancerInterceptor放入RestTemplate中的拦截器里。

SmartInitializingSingleton触发定制化
上面说了有定制化器,那什么时候进行定制化呢,就是这个时候。

这个是接口,实现了afterSingletonsInstantiated,会在所有单例bean实例化后进行调用。

DefaultListableBeanFactory的preInstantiateSingletons的最后调用:

ObjectProvider
这个其实也是一个注入点,你可以要任何类型的对象,只要他能给你注入,原理就是在DefaultListableBeanFactory的resolveDependency,直接给你创建一个DependencyObjectProvider对象返回了,你在要使用他的时候调用getIfAvailable,他相当于进行getBean处理了,因此他可以获取容器里所有的RestTemplateCustomizer实例:

RibbonAutoConfiguration
这里有两个比较重要的一个是SpringClientFactory,可以创建各种和负载均衡相关的对象,还有一个是RibbonLoadBalancerClient,做具体的负载均衡算法选择和调用。

还有默认的负载均衡器ZoneAwareLoadBalancer。

LoadBalanced注解
初始化大致的几个重要的对象都将了,但是这里有个问题,我们来看看这个注解,里面比一般的多了一个Qualifier注解,就是这个注解给要注入的对象限制了条件,必须要有LoadBalanced注解,否则不能注入。

这个就使得我们必须在注入的时候加LoadBalanced注解,否则配置类的RestTemplate集合是拿不到的:

那这个的原理是什么呢,其实就是属性注入的时候有会去判断注解上有没有Qualifier限定修饰,如果有的话,那注入的工厂方法上也应该有这个限定符,否则不给注入。具体可以看相关文章分析。
好了,今天就到这里了,希望对学习理解有帮助,大神看见勿喷,仅为自己的学习理解,能力有限,请多包涵。
本文深入剖析SpringCloud中Ribbon的初始化过程,包括LoadBalancerAutoConfiguration自动配置、RestTemplate实例集合注入、LoadBalancerInterceptor负载均衡拦截器、LoadBalancerRequestFactory请求工厂及RibbonAutoConfiguration核心组件。解读如何通过定制化器SmartInitializingSingleton触发定制化流程,以及ZoneAwareLoadBalancer等默认负载均衡器的工作原理。
555

被折叠的 条评论
为什么被折叠?



