springcloud应用之ribbon

springcloud应用之ribbon

阅读提示

请先阅读eureka

ribbon是什么

ribbon是netflix提供的一个用来解决客户端负载均衡的组件

ribbon的使用

@Configuration
public class AppConfig {

    @Bean
    @LoadBalanced
    public RestTemplate restTemplate(){
        return new RestTemplate();
    }
	//可不写rule,有默认的,应该是轮询
    @Bean
    public IRule myRule(){
        return new RetryRule();
    }
}

调用方式

@RestController
public class UserController {

    @Autowired
    private RestTemplate restTemplate;

    @RequestMapping("queryOrder")
    public String queryOrder(){
        ResponseEntity<String> response = restTemplate.getForEntity("http://order/order",String.class);
        return response.getBody();
    }
}

调用不同的微服务使用不同的算法

如果user模块想使用A负载均衡算法调用order,使用B算法调用money,可以使用如下办法:
先写两个配置文件

@Configuration
public class MoneyRuleConfig {
    @Bean
    public IRule rule(){
        return new RoundRobinRule();
    }
}

@Configuration
public class OrderRuleConfig {
    @Bean
    public IRule rule(){
        return new RandomRule();
    }
}

但是注意这两个config必须在启动类UserApplication所在包的外面,也就是compontScan包外面如图
在这里插入图片描述
可以看到config包和compontScan的 com.lry.eureka.user是平级关系
启动类加上

@RibbonClients({
        @RibbonClient(name = "money",configuration = MoneyRuleConfig.class),
        @RibbonClient(name = "order",configuration = OrderRuleConfig.class),
})

负载均衡算法

请见笔者另一篇博客
负载均衡

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值