![e30c65096803353e08071971d709b7dd.png](https://i-blog.csdnimg.cn/blog_migrate/0545eaa3ae002023c116768c5cd3128f.jpeg)
前言
最近项目采用SpringCloud微服务架构的时候,使用FeignClient实现服务之间调用,踩了一些坑,现分享给大家少采坑吧...
分页接口GET请求参数封装问题
有个分页接口,采用Get请求调用该地址。
http ://unicom-portal-pcm-service/news/getNewsArticleList?catid=1&label_id=234&collect=&top=&page=1&limit=10
后端接口方法使用一个News对象接收,但发现始终获取不到请求参数值。
![28ad1f6b7247f704755d618d62539333.png](https://i-blog.csdnimg.cn/blog_migrate/baad7fabbac71e352209bd3627601289.jpeg)
解决办法
1、对象接收请求参数要使用Post请求加注解@RequestBody
![7b4d08446a9bb1a0f5f525f5f69538f2.png](https://i-blog.csdnimg.cn/blog_migrate/a9bda51b449c7ea04cada4c9262f35ee.jpeg)
2、接收请求参数要使用Get请求,请求参数分开写
![6abe68f76092722c8287ab2e496b9636.png](https://i-blog.csdnimg.cn/blog_migrate/eb9811a5b183ce0e24a9322b1c0cb75a.jpeg)
3、接收请求参数要使用Get请求,请求参数用Map接收+@RequestParam注解
![e4b204fe594b8bd87843a71737f4635e.png](https://i-blog.csdnimg.cn/blog_migrate/ef439abef3772cf72ece8bc490ab5ced.jpeg)
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
这种是目前项目采用的
![d7af6628a88c62a9b46a7c88ac30f39f.png](https://i-blog.csdnimg.cn/blog_migrate/5a7e01849401d98ec33778b711e7ebad.jpeg)
3、禁用feign的hystrix
feign.hystrix.enabled: false
不推荐使用这种方式,除非有一些特殊场景
接口@PathVariable路径接参问题
![bc14d3640c58086707075827ffa41aa5.png](https://i-blog.csdnimg.cn/blog_migrate/85dc23a4f117696796d40ff86fc69789.jpeg)
@PathVariable(“id”) 中的”id”,不能省略,必须指定。不然获取不到id值