Spring Cloud(四)——ribbon整合

上一章主要介绍了注册中心的高可用,地址可见
https://blog.csdn.net/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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值