0
点赞
收藏
分享

微信扫一扫

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


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

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

SpringCloud - Ribbon(包含负载均衡自定义策略)_微服务_02

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

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

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

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

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

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

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

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

SpringCloud - Ribbon(包含负载均衡自定义策略)_微服务_05

Ribbon策略

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

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

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


举报

相关推荐

0 条评论