前言 前情回顾 上一讲 我们通过单元测试 来梳理了EurekaClient是如何注册到server端,以及server端接收到请求是如何处理的,这里最重要的关注点是注册表的一个数据结构:ConcurrentHashMap<String, Map<String, Lease<InstanceInfo>>>() 本讲目录 回头看了下之前的博客,没有一个总目录说明,每篇都是直接源码分析了.从此篇文章开始都会加上目录,以及文章最后会加上总结及读此篇源码的感受.希望这个博客系列的…
前言 想说的话 这里已经梳理完Eureka.Ribbon.Feign三大组件的基本原理了,今天做一个总结,里面会有一个比较详细的调用关系流程图. 说明 原创不易,如若转载 请标明来源! 博客地址:一枝花算不算浪漫 微信公众号:壹枝花算不算浪漫 总结 今天抽了一下午时间又复习了Eureka.Ribbon.Feign的源码,这里画了一个三个组件的调用关系: 图片看不清的话可以直接看我分享出来的processon地址: https://www.processon.com/view/link/5e157…
前言 想说的话 [一起学源码-微服务-Ribbon]专栏到这里就已经全部结束了,共更新四篇文章. Ribbon比较小巧,这里是直接 读的spring cloud 内嵌封装的版本,里面的各种configuration确实有点绕,不过看看第三讲Ribbon初始化的过程总结图就会清晰很多. 紧接着会继续整理学习Feign源码相关的,敬请期待. 说明 原创不易,如若转载 请标明来源! 博客地址:一枝花算不算浪漫 微信公众号:壹枝花算不算浪漫 总结 总结分为两个部分,一个是Riboon执行整体流程图,还一…
前言 前情回顾 上一讲深入的讲解了Ribbon的初始化过程及Ribbon与Eureka的整合代码,与Eureka整合的类就是DiscoveryEnableNIWSServerList,同时在DynamicServerListLoadBalancer中会调用PollingServerListUpdater 进行定时更新Eureka注册表信息到BaseLoadBalancer中,默认30s调度一次. 本讲目录 我们知道Ribbon主要是由3个组件组成的: ILoadBalancer IRule IP…
前言 前情回顾 上一篇讲了Ribbon的初始化过程,从LoadBalancerAutoConfiguration 到RibbonAutoConfiguration 再到RibbonClientConfiguration,我们找到了ILoadBalancer默认初始化的对象等. 本讲目录 这一讲我们会进一步往下探究Ribbon和Eureka是如何结合的. 通过上一讲ILoadBalancer 我们已经可以拿到一个服务所有的服务节点信息了,这里面是怎么把服务的名称转化为对应的具体host请求信息的呢…
前言 前情回顾 上一讲深入的讲解了Ribbon的初始化过程及Ribbon与Eureka的整合代码,与Eureka整合的类就是DiscoveryEnableNIWSServerList,同时在DynamicServerListLoadBalancer中会调用PollingServerListUpdater 进行定时更新Eureka注册表信息到BaseLoadBalancer中,默认30s调度一次. 本讲目录 这一讲主要是讲Fegin Demo以及通过入口注解@EnableFeignCliets和@…
前言 前情回顾 前面文章已经梳理清楚了Eureka相关的概念及源码,接下来开始研究下Ribbon的实现原理. 我们都知道Ribbon在spring cloud中担当负载均衡的角色, 当两个Eureka Client互相调用的时候,Ribbon能够做到调用时的负载,保证多节点的客户端均匀接收请求.(这个有点类似于前端调用后端时Nginx做的负载均衡) 本讲目录 本讲主通过一个简单的demo来了解ribbon内部实现,这里主要是对ribbon有个宏观的认识,后续篇章会一步步通过debug的方式对ri…
前言 前情回顾 上一讲讲了Ribbon的基础知识,通过一个简单的demo看了下Ribbon的负载均衡,我们在RestTemplate上加了@LoadBalanced注解后,就能够自动的负载均衡了. 本讲目录 这一讲主要是继续深入RibbonLoadBalancerClient和Ribbon+Eureka整合的方式. 上文我们已经知道调用RestTemplate时,会在其上面加上一个LoadBalancerInterceptor拦截器,其中会先执行LoadBalancerClient.execut…
前言 前情回顾 上一讲我们已经知道了Feign的工作原理其实是在项目启动的时候,通过JDK动态代理为每个FeignClinent生成一个动态代理. 动态代理的数据结构是:ReflectiveFeign.FeignInvocationHandler.其中包含target(里面是serviceName等信息)和dispatcher(map数据结构,key是请求的方法名,方法参数等,value是SynchronousMethodHandler). 如下图所示: 本讲目录 这一讲主要是Feign与Rib…
前言 前情回顾 上一讲主要看了@EnableFeignClients中的registerBeanDefinitions()方法,这里面主要是 将EnableFeignClients注解对应的配置属性注入,将FeignClient注解对应的属性注入. 最后是生成FeignClient对应的bean,注入到Spring 的IOC容器. 本讲目录 目录如下: registerFeignClient()回顾 FeignClientFactoryBean.getObject()解析 Feign.build…