Spring Cloud核心组件之 Ribbon

上篇说完了Feign,服务间理论上实现了互相调用。现在新的问题又来了,如果服务被调用的部署在了5台机器上,如下所示:
192.168.25.110:9000
192.168.25.112:9000
192.168.25.113:9000
192.168.25.114:9000
192.168.25.115:9000
Feign怎么知道该请求哪台机器呢?

Spring Cloud Ribbon

Ribbon就是专门解决feign不知道请求哪台服务器问题的。它的作用是负载均衡,会在每次请求时选择一台机器,均匀的把请求分发到各个机器上.
ribbon 的 负载均衡默认使用的是最经典的 round ribbon轮询算法.

Ribbon是和Feign以及Eureka紧密协作,完成工作的,具体如下:

首先Ribbon会从 Eureka Client里获取到对应的服务注册表,也就知道了所有的服务都部署在了哪些机器上,在监听哪些端口号。
然后Ribbon就可以使用默认的Round Robin算法,从中选择一台机器
Feign就会针对这台机器,构造并发起请求。
在这里插入图片描述
也就是在调用服务中 Feign创建的动态代理

@Component
@FeignClient(value = "cnooc-base")
public interface LabelClient {
    @RequestMapping(method = RequestMethod.GET,value = "/label/{id}")
   Result findById(@PathVariable("id") String id);

}

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值