在Spring Cloud Netfilx栈中,各个微服务都是以Http接口的形式暴露自身服务的,因此在调用远程服务的时候就必须使用Http客户端。我们可以使用JDK原生的URLConnection、Apache的Http Client、Netty的异步Http Client、Spring的RestTemplate,但是用起来最方便、优雅的还属Feign。
Feign是一种声明式的Http客户端,Spring Cloud应用在启动时,启动类上如果有@EnableFeignClients注解,会扫描指定路径下的拥有@FeignClient注解的接口,生成代理,并注册到Spring容器。生成代理时Feign会为每个接口方法创建一个RequestTemplate对象,该对象封装了Http请求需要的所有信息,请求参数名、请求方法等信息都是在这个过程确定的,Feign的模板化就体现在这里。
如果不使用springcloud的相关组件,调用服务需要走http,配置请求head、body,然后才能发起请求。获得响应体后,还需解析等操作,十分繁琐。
Spring Cloud的Feign组件帮我们提供了优雅的解决方案,Feign的一个关键机制就是使用了动态代理:
首先,如果你对某个接口定义了@FeignClient注解,Feign就会针对这个接口创建一个动态代理;
接着你要是调用那个接口,本质就是会调用 Feign创建的动态代理,这是核心中的核心;
Feign的动态代理会根据你在接口上的@RequestMapping等注解,来动态构造出你要请求的服务的地址;
最后针对这个地址,发起请求、解析响应
服务消费者启