之前Resttemple是根据服务名找一个服务来做,但是具体怎么做,负载均衡是怎么选择的呢。 Eureka中是客户端这边做负载均衡的,而不是服务端。
图中三个都用到了负载均衡器Ribbon,其中@LoadBlanced注解其实是Ribbon的组件。会帮你用轮询或者随机连接等实现负载均衡。
Ribbon实现软负载均衡核心有三点
1、服务发现:发现依赖服务的列表(依据服务的名字,把该服务下的实例都找出来)。
2、服务选择规则:依据规则策略如何从多个服务中选择一个有效的服务。
3、服务监听,检测失效的服务,做到高效剔除。
通过ServerList找到所有服务实例,ServerListFilter过滤一些目标结果,通过IRule选择出一些目标结果。
Feign 主要是 feign client + ribbon,feign其实就通过@FeignClient注解的接口的serviceName + ribbon拿到目标服务ip和port,然后根据@FeignClient注解的接口的某个方法上的requestMapping注解,组装成完整的请求url,然后利用restTemplate去请求目标url。
类关系分析 & 负载均衡自定义策略
Ribbon策略
1、默认是轮询 RoundRobinRule(服务按照顺序列表循环命中)。
2、Spring官网根据版本查找Ribbon目录,通过配置文件进行策略配置。
3、Product是服务名称,调整策略为随机 RandomRule 是 IRule 的实现类(举例)。