Ribbon简介
- Ribbon是Netflix发布的一个负载均衡器,它有助于控制http和tcp客户端行为。Ribbon获取提供者信息后,可以通过某种负载均衡算法,为消费者去完成http请求。
- Ribbon 本身提供了多种负载均衡策略,例如:随机选择、轮询选择、重试机制选择、根据权重选择(30s会计算一次权重)、线性轮询机制选择等7种,默认为轮询选择策略。
- 在使用eureka server时,所有的服务都是注册在eureka中,假设A服务要调用B服务,Ribbon会获取所有B服务服务实例信息,通过Ribbon负载策略选出B服务,进行http请求。当然A服务也可以指定B服务来调用,此时是通过ip地址调用,而并非服务实例名。
Ribbon通过服务名调用
1、添加pom依赖
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-ribbon</artifactId>
</dependency>
2、为Spring容器中添加RestTemplate实例,并开启负载均衡功能。
@Bean
@LoadBalanced
public RestTemplate restTemplate(){
return new RestTemplate();
}
3、ConsumerController代码
@RestController
public class ConsumerControoler {
@Autowired
private RestTemplate restTemplate;
@GetMapping("/user/{id}")
public User findUserById(@PathVariable Long id){
return restTemplate.getForObject("http://client-02/getUserById/"+ id, User.class);
}
}
4、ProviderController代码
@RestController
public class ProviderController {
@GetMapping("/getUserById/{id}")
public User getUserById(@PathVariable long id){
System.out.println("client02-node-01被调用了"); //区分两个服务是否轮询被调用
//System.out.println("client02-node-02被调用了");
if (id == 1) {
return new User(1,"admin1");
} else {
return new User(2,"admin2");
}
}
}
5、测试

通过发送http://127.0.0.1:8083/user/1请求,可通过后台日志看到client-02这两个服务被轮询调用。
Ribbon通过ip调用
1、修改ConsumerController代码,并将@LoadBalanced注解一并去掉
@RestController
public class ConsumerControoler {
@Autowired
private RestTemplate restTemplate;
@GetMapping("/user/{id}")
public User findUserById(@PathVariable Long id){
return restTemplate.getForObject("http://127.0.0.1:8082/getUserById/"+ id, User.class);
}
}
2、测试
通过发送http://127.0.0.1:8083/user/1请求,可通过后台日志看到127.0.0.1:8082这个服务被调用
3、一般在项目中有些服务调用需要负载均衡,而有些不需要,这里实例化多个RestTemplate,例如:
@Bean
@Primary
@LoadBalanced
public RestTemplate restTemplate(){
return new RestTemplate();
}
@Bean("noBalancedRestTemplate")
public RestTemplate noBalancedRestTemplate(){
return new RestTemplate();
}
4、ConsumerController修改
/**
* Created by duw on 2018/9/6
*/
@RestController
public class ConsumerControoler {
@Autowired
@Qualifier("noBalancedRestTemplate")//通过bean name,来确定使用的是哪个RestTemplate实例
private RestTemplate restTemplate;
@GetMapping("/user/{id}")
public User findUserById(@PathVariable Long id){
return restTemplate.getForObject("http://127.0.0.1:8082/getUserById/"+ id, User.class);
}
}
RestTemplate接口
get请求
ResponseEntity<T> getForEntity(url,class) 返回值ResponseEntity<T>
ResponseEntity<T> getForEntity(url,class,paramMap) 返回值ResponseEntity<T>
ResponseEntity<T> getForEntity(url,class,object...) 返回值ResponseEntity<T>
T getForObject(url,class) 返回值T
T getForObject(url,class,paramMap) 返回值T
T getForObject(url,class,object...) 返回值T
post请求
ResponseEntity<T> postForEntity(url,class) 返回值ResponseEntity<T>
ResponseEntity<T> postForEntity(url,class,paramMap) 返回值ResponseEntity<T>
ResponseEntity<T> postForEntity(url,class,object...) 返回值ResponseEntity<T>
T postForObject(url,class) 返回值T
T postForObject(url,class,paramMap) 返回值T
T postForObject(url,class,object...) 返回值T
put请求
void put(url,Object request,map)
void put(URI url,Object request,paramMap)
void put(url,Object request,object...)
delete请求
void delete(url,object)
void delete(url,paramMap)
void delete(URI url)
Ribbon对eureka外服务的支持
在前面我们能看到,ribbon实现了负载均衡,但只是支持eureka注册过的服务,在实际开发中还有除eureka外的服务也需要负载均衡怎么办,ribbon也帮我们实现了,可在application配置中添加(无验证)
client-02:
ribbon:
listOfServers: localhost:8081,localhost:8082