Spring RestTemplate作为负载平衡器客户端

Posted javaui

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Spring RestTemplate作为负载平衡器客户端相关的知识,希望对你有一定的参考价值。

RestTemplate可以自动配置为使用功能区。要创建负载平衡RestTemplate创建RestTemplate @Bean并使用@LoadBalanced限定符。

警告:通过自动配置不再创建RestTemplate bean。它必须由单个应用程序创建。
@Configuration
public class MyConfiguration {

    @LoadBalanced
    @Bean
    RestTemplate restTemplate() {
        return new RestTemplate();
    }
}

public class MyClass {
    @Autowired
    private RestTemplate restTemplate;

    public String doOtherStuff() {
        String results = restTemplate.getForObject("http://stores/stores", String.class);
        return results;
    }
}

URI需要使用虚拟主机名(即服务名称,而不是主机名)。Ribbon客户端用于创建完整的物理地址。有关 如何设置RestTemplate的详细信息,请参阅 RibbonAutoConfiguration

重试失败的请求

负载平衡RestTemplate可以配置为重试失败的请求。默认情况下,该逻辑被禁用,您可以通过将Spring重试添加到应用程序的类路径来启用它。负载平衡RestTemplate将符合与重试失败请求相关的一些Ribbon配置值。如果要在类路径中使用Spring重试来禁用重试逻辑,则可以设置spring.cloud.loadbalancer.retry.enabled=false。您可以使用的属性是client.ribbon.MaxAutoRetriesclient.ribbon.MaxAutoRetriesNextServerclient.ribbon.OkToRetryOnAllOperations。请参阅Ribbon文档 ,了解属性的具体内容。

以上是关于Spring RestTemplate作为负载平衡器客户端的主要内容,如果未能解决你的问题,请参考以下文章

Spring RestTemplate作为负载平衡器客户端

Spring Cloud Commons教程Spring RestTemplate作为负载平衡器客户端

Spring 负载均衡器、RestTemplate 和微服务问题

Spring Cloud - 在 RestTemplate 中重试工作?

Spring Cloud Alibaba - 06 RestTemplate 实现自定义负载均衡算法

Spring Cloud RestTemplate学习