Feign请求中Request header is too large 解决方案

简介: 下面介绍Feign请求中Request header is too large 解决方案

异常


首先咱们上一下控制台打印异常:


16:06:58.970 [http-nio-9220-exec-1] INFO o.a.c.h.Http11Processor -

[log,182] - Error parsing HTTP request header Note: further

occurrences of HTTP header parsing errors will be logged at DEBUG

level. java.lang.IllegalArgumentException: Request header is too large


背景


微服务接口中有一个业务,需要调用客户端接口转入了base64编码后的字符编码文件


原因:


初步一看是请求头里面携带的参数太大了导致的,默认咱们请求头允许携带的数据大小是。默认情况下,tomcat(8.0版本)允许的http请求header的最大值是8024个字节(8KB)


解决方案一(不推荐)



设置请求头大小后,重启服务即可


server:
  max-http-header-size: 102400 #文件上转大小字节


为什么不推荐方案一

刚刚开始这样是能解决问题,但是后来自己仔细一想主要有2个方面的问题,


1,这样是控制了最大上转文件大小,那么如果文件大小超过了怎么办呢,必须要人工手动调整

2,这样处理还有一个致命性问题,也就是请求头里面携带大量参数也就是会导致一个句柄连接承载资源过重,严重影响服务的吞吐量,特别是并发大的情况下。故不推荐。



解决方案二


我们使用Feign调用时,默认会将参数header中也存放一份,所以就导致了header is too large,使用MultiValueMap解决这种问题了。

服务端:


/**
 * 上传图片、视频,文件
 */
 @PostMapping(value = "/test" )
public ResultDTO test(@RequestBody  MultiValueMap<String,String> map )  throws IOException{
     String base64 = map.getFirst("key");
     System.out.println(base64);
     MultipartFile multipartFile = BASE64DecodedMultipartFileUtil.base64ToMultipart(base64);
     return ResultDTO.requestSuccess(ossService.upload(multipartFile,1));
}



客户端:


/***
 * 上转文件
 * @param map
 * @return
 */
@PostMapping(value = "inner/file/test")
ResultDTO test(MultiValueMap<String,String> map );


相关文章
|
应用服务中间件 nginx
nginx优化:URI过长或request header过大导致400或414报错
当出现URI过长或请求头过大导致400或414报错时,可以通过以下方式对Nginx进行优化: 1. 调整client_max_body_size参数:该参数用于限制请求体的大小。默认情况下,Nginx的client_max_body_size参数设置为1M。如果请求体超过这个大小,Nginx会返回400错误。您可以根据实际需求适当增加这个值,例如设置为10M或更大。 ``` http { client_max_body_size 10M; } ``` 2. 调整large_client_header_buffers参数:该参数用于调整请求头缓冲区的大
7492 0
|
存储 关系型数据库 MySQL
MySQL 处理大数据表的 3 种方案,写的太好了,建议收藏!!
MySQL 处理大数据表的 3 种方案,写的太好了,建议收藏!!
1065 0
|
Java 数据库连接 mybatis
成功解决: Invalid bound statement (not found) 在已经使用mybatis的项目里引入mybatis-plus,结果不能共存的解决
这篇文章讨论了在已使用MyBatis的项目中引入MyBatis-Plus后出现的"Invalid bound statement (not found)"错误,并提供了解决方法,主要是通过修改yml配置文件来解决MyBatis和MyBatis-Plus共存时的冲突问题。
成功解决: Invalid bound statement (not found) 在已经使用mybatis的项目里引入mybatis-plus,结果不能共存的解决
|
消息中间件 监控 JavaScript
用这4招 优雅的实现Spring Boot 异步线程间数据传递
用这4招 优雅的实现Spring Boot 异步线程间数据传递
|
分布式计算 Hadoop 大数据
优化大数据处理:Java与Hadoop生态系统集成
优化大数据处理:Java与Hadoop生态系统集成
|
Java Spring 容器
详解java参数校验之:顺序校验、自定义校验、分组校验(@Validated @GroupSequence)
详解java参数校验之:顺序校验、自定义校验、分组校验(@Validated @GroupSequence)
|
JSON 网络协议 网络安全
在Istio中,到底怎么获取 Envoy 访问日志?
Envoy 访问日志记录了通过 Envoy 进行请求 / 响应交互的相关记录,可以方便地了解具体通信过程和调试定位问题。
1297 0
在Istio中,到底怎么获取 Envoy 访问日志?
|
网络协议 应用服务中间件 Linux
centos7 Nginx Log日志统计分析 常用命令
centos7 Nginx Log日志统计分析 常用命令
530 2
|
SQL 弹性计算 分布式计算
Dataphin常见问题之执行 ODPS Sql 时抛出异常如何解决
Dataphin是阿里云提供的一站式数据处理服务,旨在帮助企业构建一体化的智能数据处理平台。Dataphin整合了数据建模、数据处理、数据开发、数据服务等多个功能,支持企业更高效地进行数据治理和分析。
|
存储 弹性计算 大数据
阿里云8核64G云服务器多少钱?2024年阿里云8核64G云服务器配置、价格、性能测评
2024年阿里云8核64G云服务器的价格为9934.16元一年。该价格基于特定的配置和促销活动,并可能因时间、活动政策、地域等因素而有所变动。关于阿里云8核64G云服务器的性能测评,该服务器配备了64GB的内存和8核的CPU,具有极高的计算能力和处理速度,适用于处理超大型数据、运行复杂应用或需要极高并发处理能力的场景。多种带宽选择(从1M到5M)可以满足不同的网络需求,确保数据传输的高效性。同时,40GB ESSD云盘提供了快速且稳定的数据存储解决方案,有助于提升整体性能。
851 0