Spring Cloud(四)——ribbon整合

本文详细介绍了Spring Cloud中的Ribbon组件在服务消费者调用服务提供者时实现的负载均衡。通过@LoadBalanced注解和自定义IRule,我们可以实现轮询和随机等不同的负载算法。此外,文章还提到了在实际项目中更常使用的Feign,其底层同样依赖Ribbon的负载均衡策略。

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

上一章主要介绍了注册中心的高可用,地址可见
https://blog.youkuaiyun.com/qq_37031675/article/details/104007366

一.说明
我们服务的消费者在调用服务的提供者,为了避免高并发请求对于服务的响应,通常会采用负载均衡,通常web项目使用的是nginx,本文介绍springcloud的另一个组件ribbon

二.代码使用

    @Bean
    @LoadBalanced
    public RestTemplate restTemplate() {
        return  new RestTemplate();
    }

服务调用端,在RestTemplate的ioc过程中添加@LoadBalanced注解

public static final String PRODUCT_GET_URL = "http://MICROCLOUD-PROVIDER-PRODUCT/prodcut/get/";
Product product = restTemplate.exchange(PRODUCT_GET_URL + id,HttpMethod.GET,new HttpEntity<Object>(httpHeaders), Product.class).getBody();

这样restTemplate在使用过程中会根据从注册中心拉取的服务列表,默认以轮询算法来访问具体服务(通过服务名)提供者ip

不想使用默认轮询?

    @Bean
    public IRule iRule(){
        return new RandomRule();
    }

将IRule配置到配置类中,就可以实现随机访问服务提供端,这样使用的负载算法是全局的!

想针对不同服务设置不同负载均衡算法?
在这里插入图片描述
不要让boot项目扫描到配置类

@Configuration
public class RibbonConfig {

    @Bean
    public IRule iRule(){
        return new RandomRule();
    }
}

然后在启动类设置不同服务不同负载方式如下,启动类添加下列注解

@RibbonClient(name = "MICROCLOUD-PROVIDER-PRODUCT",configuration = RibbonConfig.class)

三.结尾
针对ribbon其实没什么好说的,实际项目会使用feign,底层使用的也就是ribbon的轮询算法,下一张将会通过日志做具体说明。
想要实际验证的码友可从github直接拉取项目
https://github.com/managerlu/clouddemo

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值