🔥码云GVP开源项目 12k star Uniapp+ElementUI 功能强大 支持多语言、二开方便! 广告
## 基本介绍 * Feign Feign 是`Spring Cloud Netflix`组件中的一量级`Restful`的 HTTP 服务客户端,实现了负载均衡和 Rest 调用的开源框架,封装了`Ribbon`和`RestTemplate`, 实现了`WebService`的面向接口编程,进一步降低了项目的耦合度。 * 什么是服务调用 顾名思义,就是服务之间的接口互相调用,在微服务架构中很多功能都需要调用多个服务才能完成某一项功能。 * 为什么要使用Feign Feign 旨在使编写 JAVA HTTP 客户端变得更加简单,Feign 简化了`RestTemplate`代码,实现了`Ribbon`负载均衡,使代码变得更加简洁,也少了客户端调用的代码,使用 Feign 实现负载均衡是首选方案,只需要你创建一个接口,然后在上面添加注解即可。Feign 是声明式服务调用组件,其核心就是:像调用本地方法一样调用远程方法,无感知远程 HTTP 请求。让开发者调用远程接口就跟调用本地方法一样的体验,开发者完全无感知这是远程方法,无需关注与远程的交互细节,更无需关注分布式环境开发。 * Feign vs OpenFeign Feign 内置了`Ribbon`,用来做客户端负载均衡调用服务注册中心的服务。Feign 支持的注解和用法参考官方文档:`https://github.com/OpenFeign/feign`官方文档,使用 Feign 的注解定义接口,然后调用这个接口,就可以调用服务注册中心的服务。 `Feign`本身并不支持`Spring MVC`的注解,它有一套自己的注解,为了更方便的使用`Spring Cloud`孵化了`OpenFeign`。并且支持了`Spring MVC`的注解,如`@RequestMapping`,`@PathVariable`等等。`OpenFeign`的`@FeignClient`可以解析`Spring MVC`的`@RequestMapping`注解下的接口,并通过动态代理方式产生实现类,实现类中做负载均衡调用服务。