Spring Cloud Ribbon-负载均衡

本文深入探讨了Netflix的Ribbon负载均衡器,介绍了其在微服务架构中的作用,包括如何与Eureka配合实现服务间调用的负载均衡,以及如何通过服务名或IP地址进行调用。同时,文章还讲解了Ribbon的负载策略,如随机选择、轮询选择等,并展示了如何在Spring Cloud项目中配置和使用Ribbon。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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、测试

eureka server 注册中心

通过发送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

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值