前言
最近项目采用SpringCloud微服务架构的时候,使用FeignClient实现服务之间调用,踩了一些坑,现分享给大家少采坑吧...
分页接口GET请求参数封装问题
有个分页接口,采用Get请求调用该地址。
http ://unicom-portal-pcm-service/news/getNewsArticleList?catid=1&label_id=234&collect=&top=&page=1&limit=10
后端接口方法使用一个News对象接收,但发现始终获取不到请求参数值。
解决办法
1、对象接收请求参数要使用Post请求加注解@RequestBody
2、接收请求参数要使用Get请求,请求参数分开写
3、接收请求参数要使用Get请求,请求参数用Map接收+@RequestParam注解
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
这种是目前项目采用的
3、禁用feign的hystrix
feign.hystrix.enabled: false
不推荐使用这种方式,除非有一些特殊场景
接口@PathVariable路径接参问题
@PathVariable(“id”) 中的”id”,不能省略,必须指定。不然获取不到id值
本文暂时没有评论,来添加一个吧(●'◡'●)