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实现类中
}
}