提问者:小点点

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


我有一段使用RestTemplate调用REST api的代码。 我的本地系统一切正常。 但是在其他环境中部署后,代码在第一次尝试中无法工作。 它提供org.springframework.web.client.HttpServerRoreXception$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)

你能给我任何线索为什么这表现得很奇怪吗。 我无法从日志中找到答案。 谢了。


共1个答案

匿名用户

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