Netflix:Ribbon
图
Spring Cloud Ribbon是一个基于HTTP和TCP的客户端负载均衡工具,主要功能是提供客户端的软件负载均衡算法和服务调用,即存在多个相同的服务模块时,如何进行调用的场景解决方案

Ribbon

Spring Cloud Ribbon是一个基于HTTP和TCP的客户端负载均衡工具,主要功能是提供客户端的软件负载均衡算法和服务调用,即存在多个相同的服务模块时,如何进行调用的场景解决方案。将用户的请求分配到多个服务上,从而达到高可用

负载均衡简单分类

  • 集中式:在消费者和提供者之间使用设施,由设施把访问请求通过某种策略转发到服务提供者,如Nginx
  • 进程式:消费者从服务注册中心获取哪些地址可用,然后从中选择合适的,如Ribbon

使用示例

添加依赖

<!-- https://mvnrepository.com/artifact/org.springframework.cloud/spring-cloud-starter-ribbon -->
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-ribbon</artifactId>
    <version>1.4.7.RELEASE</version>
</dependency>

Ribbon需要中注册中心发现服务,所以前提需要Eureka

# Eureka
eureka:
  client:
    # 消费者不用注册
    register-with-eureka: false
    service-url:
      defaultZone: http://localhost:8000/eureka,http://localhost:8003/eureka/

修改消费者访问服务时配置采用负载均衡

@Configuration
public class RestConfigBean {

    @Bean
    // Ribbon开启负载均衡
    @LoadBalanced
    public RestTemplate getRestTemplate() {
        return new RestTemplate();
    }

}

使用示例

@RestController
public class Test {

    @Resource
    private RestTemplate restTemplate;

    // 访问地址前缀
    private static final String REST_URL_PREFIX = "http://SPRINGCLOUD-PRO";

    @RequestMapping("/test")
    public User test() {
        return restTemplate.getForObject(REST_URL_PREFIX + "/hello", User.class);
    }

}

这里的地址为服务名称

图

Eureka整合Ribbon后不再需要关系IP地址和端口,只关心服务名称

注意这里轮询的是可用的服务,而不是注册中心,消费者从注册中心获取了可用服务的列表,然后再Ribbon的机制下进行选择合适的,那么相同服务的名字spring.application.name应该是一致的

图

Ribbon访问流程

图

选择Ribbon负载机制

@Configuration
public class RestConfigBean {

    @Bean
    // Ribbon开启负载均衡
    @LoadBalanced
    public RestTemplate getRestTemplate() {
        return new RestTemplate();
    }

    @Bean
    public IRule myIRule() {
        // 随机
        return new RandomRule();
        // 其他都在IRule实现类中
    }

}