注解式HTTP请求Feign (F版)
Spring Cloud为开发者提供了在分布式系统中的一些常用的组件(例如配置管理,服务发现,断路器,智能路由,微代理,控制总线,一次性令牌,全局锁定,决策竞选,分布式会话集群状态)。使用Spring Cloud开发人员可以快速地完成实现这些模式的服务和应用程序。它们在任何分布式环境中都能很好地工作
Feign
注解式的 Feign 使得 Java HTTP 客户端编写更方便。Feign 灵感来源于安卓网络编程框架 Retrofit、JAXRS-2.0 和 WebSocket,支持可插拔编码器和解码器,降低 HTTP API 的复杂度,通过最少的资源和代码来实现和 HTTP API 的连接。通过可定制的解码器和错误处理,可以编写任意的HTTP API。Spring Cloud Feign 封装了 Ribbon 这一组件,所以在使用 Feign 同时还能提供负载均衡的功能,这一切只需要一个 @FeignClient 即可完成。
早期版本的 Feign 被 Spring Cloud 团队集成在 spring-cloud-netflix 子项目下,但如今 Spring Cloud 团队将 Spring Cloud Feign独立成一个单独的 spring-cloud-openfeign 项目
Try
准备三个工程,分别是 eureka-server、order-server、product-server
Eureka Server
详情参考第一章,或从文末的 GITHUB 链接获取对应篇幅的完整代码
Product Server
一个普通的 Eureka Client 即可,详情参考上一章,或从文末的 GITHUB 链接获取对应篇幅的完整代码
Order Server
这个例子也是在上一章的基础之上做了扩展
依赖
对比上一章,此处多了一个 spring-cloud-starter-openfeign 的依赖
| 1 | <dependencies> | 
配置文件
在 src/main/resources 目录下创建一个 bootstrap.yml 的文件,写上 eureka 相关配置信息
| 1 | server: | 
ProductClient 接口
创建一个 ProductClient ,是不是感觉和 XxxxService 看起来类似(用法都类似),都是接口文件只不过在这个文件的上方多了一个 @FeignClient 注解,多种写法,总有一款适合你
- name:指定- FeignClient的名称,该属性会作为微服务的名称,用于服务发现
- value:同- name字段互通
- serviceId:指定服务ID,每个注册到注册中心上的客户端都会有对应的- serviceId一般是- spring.application.name,与- name和- value互通
- url: 一般用于调试,可以指定一个详细地址(http://localhost:8080/products)
- path: 请求统一路径,可以看成- @RequestMapping("/products")
- decode404:404 错误时,调用- decoder进行解码,否则抛出- FeignException
- fallback:发生错误时,回调- hystrix类/方法(后面会详细介绍)
| 1 | package com.battcn.api; | 
OrderController
直接使用 @Autowired 注入进去即可,然后调用就好了,对比较 Ribbon 这里我们看不到 RestTemplate 的代码了,也无需自己做解码映射,Spring Cloud Feign 默认都替我们实现好了,我们只需要遵循既定的标准即可
| 1 | package com.battcn.controller; | 
主函数
通过 @EnableFeignClients 注解开启对 Feign 的支持,用习惯 Dubbo 的朋友喜欢将 API 打包成独立的 JAR ,这个时候需要指定 basePackage 属性。
| 1 | package com.battcn; | 
 
                    
                
 
                
            
         浙公网安备 33010602011771号
浙公网安备 33010602011771号