Ribbon常用注解及配置
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
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超时时长配合的问题,详解可参看我的另⼀篇《)。