Spring Cloud中,Feign常见问题总结

Spring Cloud中,Feign常见问题的总结。

FeignClient接口,不能使用@GettingMapping 之类的组合注解

代码示例:
Spring Cloud中,Feign常见问题总结_第1张图片

这边的@RequestMapping(value = “/simple/{id}”, method = RequestMethod.GET) 不能写成@GetMapping("/simple/{id}") 。

FeignClient接口中,如果使用到@PathVariable ,必须指定其value

代码示例:
Spring Cloud中,Feign常见问题总结_第2张图片

这边的@PathVariable(“id”) 中的”id”,不能省略,必须指定。

FeignClient多参数的构造

如果想要请求microservice-provider-user 服务,并且参数有多个例如:http://microservice-provider-user/query-by?id=1&username=张三 要怎么办呢?

直接使用复杂对象:
Spring Cloud中,Feign常见问题总结_第3张图片

该请求不会成功,只要参数是复杂对象,即使指定了是GET方法,feign依然会以POST方法进行发送请求。

正确的写法:

写法1:
Spring Cloud中,Feign常见问题总结_第4张图片

写法2:

Spring Cloud中,Feign常见问题总结_第5张图片

Feign如果想要使用Hystrix Stream,需要做一些额外操作

我们知道Feign本身就是支持Hystrix的,可以直接使用@FeignClient(value = “microservice-provider-user”, fallback = XXX.class) 来指定fallback的类,这个fallback类集成@FeignClient所标注的接口即可。

但是假设我们需要使用Hystrix Stream进行监控,默认情况下,访问http://IP:PORT/hystrix.stream 是个404。如何为Feign增加Hystrix Stream支持呢?

需要以下两步:

第一步:添加依赖,示例:

第二步:在启动类上添加@EnableCircuitBreaker 注解,示例:

Spring Cloud中,Feign常见问题总结_第6张图片

这样修改以后,访问任意的API后,再访问http://IP:PORT/hystrix.stream,就会展示出一大堆的API监控数据了。

如果需要自定义单个Feign配置,Feign的@Configuration 注解的类不能与@ComponentScan 的包重叠

如果包重叠,将会导致所有的Feign Client都会使用该配置。

首次请求失败

@FeignClient 的属性注意点

(1) serviceId属性已经失效,尽量使用name属性。例如:

这么写是不推荐的,应写为:

(2) 在使用url属性时,在老版本的Spring
Cloud中,不需要提供name属性,但是在新版本(例如Brixton、Camden)@FeignClient必须提供name属性,并且name、url属性支持占位符。例如:

欢迎大家和我一起学习spring cloud构建微服务云架构,我这边会将近期研发的spring cloud微服务云架构的搭建过程和精髓记录下来,帮助更多有兴趣研发spring cloud框架的朋友,大家来一起探讨spring cloud架构的搭建过程及如何运用于企业项目

我本人邀约各大BATJ架构大牛共创Spring Cloud构建微服务架构的交流社区。 (群号:547793198)欢迎各路架构师、开发者,学习与交流使用Spring Cloud诸多强大组件的实战经验。

为什么某些人会一直比你优秀,是因为他本身就很优秀还一直在持续努力变得更优秀,而你是不是还在满足于现状内心在窃喜!

合理利用自己每一分每一秒的时间来学习提升自己,不要再用"没有时间“来掩饰自己思想上的懒惰!趁年轻,使劲拼,给未来的自己一个交代!

希望此文能帮到大家的同时,也听听大家的观点。欢迎留言讨论,加关注,分享你的高见!持续更新

  • To-陌霖Java架构

分享互联网最新文章 关注互联网最新发展

你可能感兴趣的:(Spring,Cloud,Java架构师笔记)