欢迎来到代码驿站!

JAVA代码

当前位置:首页 > 软件编程 > JAVA代码

springcloud使用feign调用服务时参数内容过大问题

时间:2022-09-19 09:28:01|栏目:JAVA代码|点击:

feign调用服务时参数内容过大

场景

前端参数传入到gateway后,gateway使用feign调用服务时,传入的参数内容过大(参数常见于富文本、或者其他附属信息过多)会导致传输不过去,虽然配置可以调节内容大小,但是最大的也有上限,所以特殊处理一道。

例如该类参数:

解决方法

可新增两个redis公共方法,后续出现的都可以共用

1、设置缓存参数:

对于请求参数数量不多,但是某些请求参数过大的场景,临时将参数body缓存在redis中,通过传递缓存key(tsparamPlaceContent),在后续接口获取请求体

2、获取缓存参数:

对于请求参数过大的请求,通过传递过来的缓存key(tsparamPlaceContent),获取请求体

大致步骤就是这样,具体怎么实现,根据各个项目不同代码去实现,该种解决方案也可适用于MQ在服务之间发送消息时内容过大的问题

feign消费时,如果传入参数过长

导致feign.FeignException: status 400 reading错误

抛出异常:

feign.FeignException: status 400 reading ProjectFeignClient#getPartsByNodes(String,List)

原因:

查询时,list<integer>中有600个参数

解决办法

查询数据时,分批查,每次500左右

上一篇:java中的SpringBoot框架

栏    目:JAVA代码

下一篇:Java 基础全面讲解StringBuffer类的使用

本文标题:springcloud使用feign调用服务时参数内容过大问题

本文地址:http://www.codeinn.net/misctech/214093.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有