天天看点

Ribbon

Ribbon

负载均衡有哪些方式

1)服务器端负载均衡 Nginx

2)客户端侧负载均衡 Ribbon

Ribbon是什么

Ribbon是Netflix发布的云中间层服务开源项目,其主要功能是提供客户端侧负载均衡算法。Ribbon客户端组件提供一系列完善的配置项如连接超时,重试等。简单的说,Ribbon是一个客户端负载均衡器,我们可以在配置文件中列出Load Balancer后面所有的机器,Ribbon会自动的帮助你基于某种规则(如简单轮询,随机连接等)去连接这些机器,我们也很容易使用Ribbon实现自定义的负载均衡算法。

下图展示了Eureka使用Ribbon时候的大致架构:

Ribbon工作时分为两步:第一步先选择 Eureka Server, 它优先选择在同一个Zone且负载较少的Server;第二步再根据用户指定的策略,在从Server取到的服务注册列表中选择一个地址。其中Ribbon提供了多种策略,例如轮询round robin、随机Random、根据响应时间加权等。

Ribbon 示例

Ribbon自定义配置

Ribbon脱离Eureka使用

使用原生的Ribbon API

实现上加 @LoadBalanced就具有Ribbon的功能:

@Bean

@LoadBalanced

public RestTemplate restTemplate() {

return new RestTemplate();

}

继续阅读