RestTemplate有时会出现500内部服务器错误。

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

我有一段使用RestTemplate调用REST api的代码。在我的本地系统中,一切都运行得很好。但在其他环境中部署后,第一次尝试时代码就无法工作。它给出的是 org.springframework.web.client.HttpServerErrorException$InternalServerError. 然而,如果我再次调用这个方法,它就会工作。我不知道为什么这个方法表现得很奇怪。在我的情况下,每一次偶数尝试都是有效的。这是我的代码块。

final String url = this.environment.getProperty("app.base-uri") + "/testEmail/";

final HttpHeaders httpHeaders = new HttpHeaders();
httpHeaders.setContentType(MediaType.APPLICATION_JSON);
httpHeaders.set(Constants.AUTHORIZATION, this.getRequestAuthorizationHeader());

final HttpEntity<EmailRequestModel> httpEntity = new HttpEntity<>(emailRequestModel, httpHeaders);

final ResponseEntity<String> emailResponseEntity = new RestTemplate().postForEntity(url, httpEntity, String.class);

这里是日志

org.springframework.web.client.HttpServerErrorException$InternalServerError:
   at org.springframework.web.client.HttpServerErrorException.create (HttpServerErrorException.java100)
   at org.springframework.web.client.DefaultResponseErrorHandler.handleError (DefaultResponseErrorHandler.java172)
   at org.springframework.web.client.DefaultResponseErrorHandler.handleError (DefaultResponseErrorHandler.java112)
   at org.springframework.web.client.ResponseErrorHandler.handleError (ResponseErrorHandler.java63)
   at org.springframework.web.client.RestTemplate.handleResponse (RestTemplate.java785)
   at org.springframework.web.client.RestTemplate.doExecute (RestTemplate.java743)
   at org.springframework.web.client.RestTemplate.execute (RestTemplate.java677)
   at org.springframework.web.client.RestTemplate.postForEntity (RestTemplate.java452)
   at com.toyota.tmi.service.impl.ExtraRequestServiceImpl.sendWorkflowEmail (ExtraRequestServiceImpl.java1153)

你能不能给我点线索,为什么会出现这种奇怪的情况?我无法从日志中找出答案。我无法从日志中找出答案,谢谢。

java spring spring-boot rest resttemplate
1个回答
0
投票

你能不能在服务端也看到任何错误,或者它只是客户端.你提供的代码快照似乎很好。

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