java - Spring 端点为较大的 http 请求接收截断的正文
问题描述
我有一个组件,部署在 AWS 上的 EC2 实例中,当发送更大的有效负载(40k)时,它将“随机”失败(约 70% 的请求)。
发送请求是使用 Postman 完成的。一遍又一遍地发送相同的请求(之间有相同的延迟或尽可能快地发送),每次我遇到一些失败,然后成功(有时连续 2 次,然后一些失败,重复)
这是一个 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);
对于每个请求(失败或成功),我都会为 content-length-header 获得相同的值。数据长度要么相同(调用成功),要么更短(调用失败)。
我如上所述添加了一些日志记录,这似乎证明了接收到的数据实际上被截断了。
我启用了访问日志使用
server.tomcat.accesslog.pattern=%h %l %u %t "%r" %s %b %{content-length}i %{Content-Length}i
access-log 显示与 content-length-header 相同的值。
环顾四周,我发现了几篇文章,没有一个我可以使用的答案。考虑到这也成功了 30%(或较小的请求),我认为代码本身可能没问题。只是不知道下一步要更改什么以进一步调查。
一些对我的问题没有帮助的相关链接(可能对其他人有帮助):
解决方案
在我们的案例中,我们遇到了类似的问题,请求被随机截断(~ 10-20%)。相同的应用程序版本部署在多个环境中。该问题仅存在于某些环境中。我们尝试通过执行以下操作来重现该问题:
- 将应用程序 API 端点从 HTTPS 更改为 HTTP,没有任何问题。我们还将 ALB 的后端协议从 HTTPS 更改为 HTTP。
- 尝试从 localhost 访问 HTTPS 端点。该问题不存在。
后来我们检查了到位的应用程序服务器。我们在 9.0.31 的 Spring Boot 应用程序中使用了嵌入式 tomcat。已知此版本的 tomcat 在 HTTPS 上的有效负载方面存在问题。通过在 pom.xml 中明确定义此版本将 tomcat 版本更改为 9.0.30 为我们解决了这个问题。
相关链接,以便这可以帮助其他人:
推荐阅读
- css - 有没有办法 :first-of-type::first-letter 除非元素具有给定类型的父级?
- google-apps-script - 修改代码 - 将永久抄送添加到 MailMerge - Google 表格/Google Apps 脚本
- python - 如何使用 SpaCy 解决西班牙语词形还原问题?
- java - 代码在 Java 递归中返回堆栈溢出错误
- asp.net-mvc - IdentityServer4 客户端应用程序:ArgumentNullException:IDX10000:参数“hashAlgorithm”不能是“null”或空对象
- android - 设置firebase时出错,可能会出现未处理的承诺拒绝
- linux - Poco::Net::HTTPSClientSession receiveResponse 总是被异常截断
- ios - 删除、添加或修改 Firestore 文档和分页结果后重新加载 TableView
- c++ - 为什么 unique_ptr 和 shared_ptr 不会使构造它们的指针无效?
- python - 如何改变 wxpython 的方向?