RestTemplate 请求中的连接超时无法正常工作

问题描述 投票:0回答:1

我正在使用 RestTemplate 从外部服务获取数据,我想为请求设置超时,如下所示:

        CloseableHttpClient client = HttpClients.custom().setDefaultRequestConfig(RequestConfig.custom().setConnectTimeout(600000).setConnectionRequestTimeout(600000).setSocketTimeout(600000).build()).build();

        HttpComponentsClientHttpRequestFactory requestFactory = new HttpComponentsClientHttpRequestFactory();
        requestFactory.setHttpClient(client);
        requestFactory.setConnectTimeout(600000);
        requestFactory.setConnectionRequestTimeout(600000);
        requestFactory.setReadTimeout(600000);

        RestTemplate restTemplate = new RestTemplate(requestFactory);

        HttpHeaders headers = new HttpHeaders();
        headers.add("Authorization", "Basic " + settings.getBase64EncodedAuthString());
        headers.setContentType(MediaType.APPLICATION_JSON);
        HttpEntity<BaseParameters> request = new HttpEntity<>(parameters, headers);

        ResponseEntity<MyResponse> response = restTemplate.exchange("https://my-external-service.com/service1", HttpMethod.POST,
                    request, MyResponse.class);

虽然我将超时设置为600000ms(10分钟),但有时我仍然在仅20秒后从服务器收到超时异常,这是我得到的异常:

org.springframework.web.client.ResourceAccessException -> I/O 错误 POST 请求 “https://my-external-service.com/service1”: 连接到 my-external-service.com:443 失败:连接超时: 连接;嵌套异常是 org.apache.http.conn.HttpHostConnectException:连接到 我的外部服务.com:443 失败:连接超时:连接

有谁知道我在这里的超时配置是否有问题,或者我是否需要配置更多内容?谢谢你

java spring httpclient resttemplate connection-timeout
1个回答
0
投票

您正在使用 HTTP 请求配置,请求级别配置仅在连接路由完全建立后才适用。它不适用于 SSL 握手或 CONNECT 请求。您需要配置连接管理器在创建连接时应用的套接字属性。

此链接会有帮助https://github.com/spring-projects/spring-boot/issues/11379

© www.soinside.com 2019 - 2024. All rights reserved.