SpringCloud - Ribbon(包含负载均衡自定义策略)

5d2f178f0001e70819201080.jpg (1920×1080)

  • 之前Resttemple是根据服务名找一个服务来做,但是具体怎么做,负载均衡是怎么选择的呢。 Eureka中是客户端这边做负载均衡的,而不是服务端。
  • 图中三个都用到了负载均衡器Ribbon,其中@LoadBlanced注解其实是Ribbon的组件。会帮你用轮询或者随机连接等实现负载均衡。

5cb1d05500014cb019201080.jpg (1920×1080)

Ribbon实现软负载均衡核心有三点

1、服务发现:发现依赖服务的列表(依据服务的名字,把该服务下的实例都找出来)。

2、服务选择规则:依据规则策略如何从多个服务中选择一个有效的服务。

3、服务监听,检测失效的服务,做到高效剔除。

5d2f18590001f1c219201080.jpg (1920×1080)

  • 通过ServeList找到所有服务实例,ServerListFilter过滤一些目标结果,通过IRule选择出一些目标结果。
  • Feign 主要是 feign client + ribbon,feign其实就通过@FeignClient注解的接口的serviceName+ribbon拿到目标服务ip和port,然后根据@FeignClient注解的接口的某个方法上的requestMapping注解,组装成完整的请求url,然后利用restTemplate去请求目标url。

 

类关系分析 & 负载均衡自定义策略

5e905d86000192bc19201080.jpg (1920×1080)

5cbd6c9f0001b76419201080.jpg (1920×1080)

Ribbon策略

1、默认是轮询 RoundRobinRule(服务按照顺序列表循环命中)

2、Spring官网根据版本查找Ribbon目录,通过配置文件进行策略配置。

3、Product是服务名称,调整策略为随机 RandomRule 是 IRule 的实现类(举例)。

发布了952 篇原创文章 · 获赞 1820 · 访问量 89万+

猜你喜欢

转载自blog.csdn.net/Dream_Weave/article/details/105440160