Spring Cloud 2.2.2 源码之十九Ribbon执行原理五

基本流程图

Spring Cloud 2.2.2 源码之十九Ribbon执行原理五

准备执行

服务器选完之后创建一个RibbonServer,封装一些信息,执行。
Spring Cloud 2.2.2 源码之十九Ribbon执行原理五

execute

创建RibbonLoadBalancerContext上下文和状态记录器RibbonStatsRecorder做点计时,最后调用最开始封装的新请求的apply方法:
Spring Cloud 2.2.2 源码之十九Ribbon执行原理五

InterceptingRequestExecution的execute

最后再包装成ServiceRequestWrapper,让拦截执行器InterceptingRequestExecution继续执行。
Spring Cloud 2.2.2 源码之十九Ribbon执行原理五
最后内部就是发送请求给替换后的服务器了:
Spring Cloud 2.2.2 源码之十九Ribbon执行原理五
这样基本的流程说完了,很多细节还是要自己看,比如负载均衡策略,其实有那么多:
Spring Cloud 2.2.2 源码之十九Ribbon执行原理五
比如RandomRule随机选择:
Spring Cloud 2.2.2 源码之十九Ribbon执行原理五
当然如果你要自定义规则,实现这个接口就好:
Spring Cloud 2.2.2 源码之十九Ribbon执行原理五
比如随便写一个:
Spring Cloud 2.2.2 源码之十九Ribbon执行原理五
注入,如果放在可扫描的包下就变成全局共享啦,另外一种就是用RibbonClient注解指定,怎么用就不多说了:
Spring Cloud 2.2.2 源码之十九Ribbon执行原理五
结果:
Spring Cloud 2.2.2 源码之十九Ribbon执行原理五
好了,其他的细节只能慢慢看啦,先知道基本原理吧,其他都不是大问题。

好了,今天就到这里了,希望对学习理解有帮助,大神看见勿喷,仅为自己的学习理解,能力有限,请多包涵。

相关文章: