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
ribbon.MaxAutoRetries=1
ribbon.MaxAutoRetriesNextServer=0
通常配置ribbon.ReadTimeout和ribbon.ConnectTimeout即可(注意和hystrix超时时长配合的问题,详解可参看我的另一篇《openFeign常用注解及超时时间规则详解》)