feign踩坑_SpringCloud实战:Feign你不知道的一些坑

本文分享了在使用SpringCloud的Feign进行服务间调用时遇到的三个问题:分页接口GET请求参数封装、feign请求超时和fallback异常、@PathVariable路径参数接收。对于分页接口,提出了解决请求参数接收的方法;对于超时问题,给出了调整Feign超时时间和禁用Hystrix超时的策略;对于@PathVariable,强调了不能省略参数名的重要性。
摘要由CSDN通过智能技术生成
a46d7d77609eba4ac97581ce6dc73c08.png

前言

最近项目采用SpringCloud微服务架构的时候,使用FeignClient实现服务之间调用,踩了一些坑,现分享给大家少采坑吧...

分页接口GET请求参数封装问题

有个分页接口,采用Get请求调用该地址。

http ://unicom-portal-pcm-service/news/getNewsArticleList?catid=1&label_id=234&collect=&top=&page=1&limit=10

后端接口方法使用一个News对象接收,但发现始终获取不到请求参数值。

bc9fd2ad422bb8af30080d3f89a4193f.png

解决办法

1、对象接收请求参数要使用Post请求加注解@RequestBody

4b7f47cd6c66e958314b2a1a351bb18e.png

2、接收请求参数要使用Get请求,请求参数分开写

08c82d9ed75990769f7a87eb22f07e07.png

3、接收请求参数要使用Get请求,请求参数用Map接收+@RequestParam注解

98be2f4817c01e19b73f14c06bec4cee.png

feign请求超时和fallback异常

原因是Hystrix默认的超时时间是1秒,如果超过1秒未响应,将会进入fallback代码。

另外首次请求往往会比较慢(因为spring的懒加载机制),这个响应时间可能就大于1秒了。

解决办法

1、把Feign超时时间设长点,例如5秒

hystrix.command.default.execution.isolation.thread.timeoutInMilliseconds: 5000

2、禁用Hystrix的超时

hystrix.command.default.execution.timeout.enabled: false

这种是目前项目采用的

ccbc6ab635159836055ec6772d108f87.png

3、禁用feign的hystrix

feign.hystrix.enabled: false

不推荐使用这种方式,除非有一些特殊场景

接口@PathVariable路径接参问题

a655c02a180b89b23e3f62f96b0e6ade.png

@PathVariable(“id”) 中的”id”,不能省略,必须指定。不然获取不到id值

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值