Spring Cloud Ribbon

关键点1:pom.xml

<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-netflix-ribbon</artifactId>
    <version>2.2.2.RELEASE</version>
</dependency>

如果使用了Eureka2.x,可用不引入,因为Eureka2.0后默认自动引入

<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
    <version>2.2.2.RELEASE</version>
</dependency>

 

关键点2: 定义RestTemplate

@Configuration
public class RestTemplateConfig {

    @Bean
    @LoadBalanced // 赋予RestTemplate负载均衡的能力
    public RestTemplate getRestTemplate()
    {
        return new RestTemplate();
    }
}

Controller示例

 @GetMapping("/payment/get/{id}")
    public CommonResult<Payment> getPaymentById(@PathVariable("id") Integer id)
    {
        return restTemplate.getForObject(PAYMENR_URI + "/payment/get/" + id, CommonResult.class);
    }

 

 

Ribbon查询策略

com.netflix.loadbalancer.RoundRobinRule 轮询

com.netflix.loadbalancer.RandomRule 随机

com.netflix.loadbalancer.RetryRule 先安装RoundRobinRule的策略获取服务,如果获取服务失败则再指定时间内会进行重试,获取可用服务

WeightedResponseTineRule 对RoundRibinRUle的扩展,响应速度越快的实例选择权重越大,越容易被选择

BestAvailableRule 会先过滤掉由于多次访问故障而处于断路器跳闸状态的服务,然后选择一个并发量小的服务

AvailabilityFilteringRule 会过滤掉故障实例,再选择并发较小的实例

ZoneAvoidanceRule 默认规则,符合判断server所在区域的性能和server的可用性选择

 

 

Ribbon更换查询策略,比如换成随机

先自定义配置类,这里需要注意:

Ribbon自定义配置类不能再@ComponentScan所扫描的当前包及其子包下,否则自定义的这个配置类就会被所有Ribbon客户端共享,达不到特殊化定制的目的

 

 

自定义配置类

@Configuration
public class RibRule {
    @Bean
    public IRule myRule()
    {
        return new RandomRule(); // 自定义为随机查询
    }
}

 

使用

在启动类上加上配置类

@RibbonClient(name = "TCLOUD-PAYMENT-PROVIDER", configuration = RibRule.class)

name表示哪个服务,对应Eureka的Application

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值