关键点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