Ribbon常用注解及配置

Ribbon在服务调用方使用

常用注解及范例:(服务调用方)

主类中:

@Bean
@LoadBalanced  //在RestTemplate上加入负载均衡注解
public RestTemplate restTemplate(){
return new RestTemplate();
}

服务调用代码:

@GetMapping("{id}")
public User queryById(@PathVariable("id") Long id){
String url = "http://user-server/user/"+id; //此处直接写服务ID即可
User user = restTemplate.getForObject(url, User.class);
return user;
}

 原理:

ribbon会拦截RestTemplate之后取出"user-server"字符串,以"user-server"作为服务ID找eureka获取服务实例,之后自动进行拼接(即自动拼接地址及端口),并使用拼接后的url重新发送请求

因此@LoadBalanced注解必须加在RestTemplate类上

 

ribbon配置:

ribbon.ReadTimeout=1000 //处理请求的超时时间,默认为1秒
ribbon.ConnectTimeout=1000 //连接建立的超时时长,默认1秒
ribbon.MaxAutoRetries=1 //同一台实例的最大重试次数,但是不包括首次调用,默认为1次
ribbon.MaxAutoRetriesNextServer=0 //重试负载均衡其他实例的最大重试次数,不包括首次调用,默认为0次
ribbon.OkToRetryOnAllOperations=false //是否对所有操作都重试,默认false

通常配置ribbon.ReadTimeout和ribbon.ConnectTimeout即可(注意和hystrix超时时长配合的问题,详解可参看我的另一篇《openFeign常用注解及超时时间规则详解》

posted @ 2019-10-15 16:55  WaterGe  阅读(3675)  评论(0编辑  收藏  举报