作用 在使用 RestTemplate 的时候 如果 RestTemplate 上面有 这个注解,那么 这个 RestTemplate 调用的 远程地址,会走负载均衡器。
使用:
1
2
3
4
5
6
7
8
9
|
@Bean @LoadBalanced RestTemplate restTemplate() { return new RestTemplate(); } @LoadBalanced @Autowired(required = false ) private List<RestTemplate> restTemplates = Collections.emptyList(); |
原理:
使用了这个注解以后 ,会在 restTemplate 里面 通过 restTemplate.setInterceptors 放入 LoadBalancerInterceptor ,这个过滤器会在 请求远程成接口的时候 动态判断请求的域是不是 负载 负载均衡支付的服务的地址,如果是,那么就会代理 使用 这个负载均衡器 来调用。
1
2
3
4
5
6
7
8
|
@Override public ClientHttpResponse intercept(final HttpRequest request, final byte [] body, final ClientHttpRequestExecution execution) throws IOException { final URI originalUri = request.getURI(); String serviceName = originalUri.getHost(); Assert.state(serviceName != null , "Request URI does not contain a valid hostname: " + originalUri); return this .loadBalancer.execute(serviceName, requestFactory.createRequest(request, body, execution)); } |