我有一个组件,部署在 AWS 上的 EC2 实例中,当发送较大的有效负载 (40k) 时,该组件会“随机”失败(约 70% 的请求)。
发送请求是使用 Postman 完成的。一遍又一遍地发送相同的请求(之间有相同的延迟或尽可能快),每次我都会遇到一些失败,然后成功(有时连续两次,然后出现一些失败,重复)
这是一个 Java Spring Boot 应用程序,控制器片段:
@PostMapping
@RequestMapping("/some/url")
ResponseEntity<MyClass> methodName(@RequestBody String data, @RequestHeader("content-length") String header) {
log.info("Content-Length header was: "+header);
log.info("Length of inputJson (@RequestBody) was: "+data.length());
log.info(inputJson);
Run Code Online (Sandbox Code Playgroud)
对于每个请求(失败或成功),我都会获得相同的内容长度标头值。数据长度要么相同(成功调用),要么更短(失败调用)。
我添加了一些如上所述的日志记录,这似乎证明接收到的数据实际上被截断了。
我使用启用了访问日志
server.tomcat.accesslog.pattern=%h %l %u %t "%r" %s %b %{content-length}i %{Content-Length}i
Run Code Online (Sandbox Code Playgroud)
访问日志显示与内容长度标头相同的值。
环顾四周,我发现了几篇文章,但没有一篇文章有我可以使用的答案。考虑到这也成功了 30%(或较小的请求),我认为代码本身可能没问题。只是不知道接下来要改变什么以进一步调查这一点。
一些相关链接对我的问题没有帮助(可能对其他人有帮助):