java

关注公众号 jb51net

关闭
首页 > 软件编程 > java > SpringCloud使用feign调用错误

SpringCloud使用feign调用错误的问题

作者:想学Java的小码农

这篇文章主要介绍了SpringCloud使用feign调用错误的问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

SpringCloud使用feign调用错误

首先启动类上扫描接口:

@EnableFeignClients(value = {"com.xxx.*.xxx.controller"})

不然编译器会报红色波浪线

Method has too many Body parameters 可能原因

方法内参数不止一个

1、如果是例如:

可以使用@RequestParam注解:

2、使用对象:

 

解决办法有两个:

1、使用注解@SpringQueryMap

2、把这两个对象整合为一个,例如把User中相关属性写到PageRequest中,保证只有一个对象。

Method metrics not annotated with HTTP method type (ex. GET, POST)

可能原因:接口处有方法没有添加和@GetMapping功能类似的注解,即便具体业务没有做,也要加上,否则导入的服务无法启动。

调用接口得到了莫名其妙的结果

可能原因:由于现在大多数采用resultful风格接口,而默认的feign使用GET请求调用接口,目标接口是使用对象接收时,会转为POST请求,你会看到日志里接口由GET自动变为了POST。

解决办法:

1、改为POST请求,如果接口是别人提供的就无法使用,因为可能别人服务已经联调好了,再去改很麻烦,加上别人很忙,可能也不会回头来给你改。

2、目标接口参数加上@SpringQueryMap,不过有可能像我在协同开发的时候,服务是别人的,无法改变别人的服务,那么只能换其它方式了。

3、本服务加上这两个依赖

<!-- httpclient -->
<dependency>
    <groupId>org.apache.httpcomponents</groupId>
    <artifactId>httpclient</artifactId>
    <version>4.5.9</version>
</dependency>
<!-- feign-httpclient -->
<dependency>
    <groupId>io.github.openfeign</groupId>
    <artifactId>feign-httpclient</artifactId>
  <version>10.2.3</version>
</dependency>

4、像我们项目,本来我使用第3种方法解决,可能我们组长说我为什么导入这两个依赖,我解释之后,他新写了一个POST接口用于调用,所以最后究竟选择什么办法,还是看你们组长决定,哈哈。

5、再说一下,其实你自己无法改变别人的接口参数,你可以写一个一样的,只要请求地址正确,完全可以使用,例如他死活不愿意加注解,你可以在自己的新建的接口加上任意注解参数,也是可以使用的,但是极其不推荐,弊端很多,但是可以用于测试,最后还是去沟通一下,找组长。再说一遍:别这么干。

SpringCloud之Feign调用400错误问题

项目在本地环境一直在正常运行,突然测试环境大量报错,点哪错哪.

项目报错的接口是 A服务通过feign调用B服务,但是会通过两个接口调用两次B服务

查看测试环境日志发现错误如下:

这里只展示主要异常信息

feign.FeignException: status 400 reading

一开始我们被这个400的错误码误导了,一直查参数问题,但是换了所有参数后,还是报这个错,总之网上的解决办法能找的都找了.什么参数不对,序列化不对,参数过大,返回值过大,豪猪超时.甚至是服务器重启都试过,还是没能解决问题

最后的最后,直接上干货,如果上述方法你都试过,但是还是没能解决的话,那么你可能是跟我一样的问题.

直接贴干货代码:

@RequestMapping(value ="/api/getBeingProject",headers = {"Connection=close"})
List<SysProject> getBeingProject(@RequestParam String entId);

上述是自定义client中的一个远程方法,在方法上加入关键的

headers = {"Connection=close"}

这代表这次调用后,会立马关闭回收连接.

结论:

通过公司几位大佬各种跟源码分析,情况可能是这样的,

两次调用都会从连接池去拿连接

有可能是第一次调用的连接需要2秒钟

但是1秒就执行完毕了,然后第二次连接就过来了

直接拿了第一次剩下的连接去用

然后就直接把本次连接拒绝掉

feign就会报400错误,在方法上加这个headers后

本次调用后,会立马回收关闭连接,不给其他人拿到这次连接的机会,就解决了问题

彩蛋:

所有环境都没问题后,发布线上,发现线上还是会有一个接口还出现同样的问题.最后发现是这个接口请求的数据有点大,然后分批次去请求就解决了问题。 

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

您可能感兴趣的文章:
阅读全文