概述
Feign是一个声明式的Web Service客户端,是一种声明式、模板化的客户端。可以做到使用HTTP请求访问远程服务,就像调用本地方法一样的。特性:
- 可插拔的注解支持,包括Feign注解和JAX-RS注解。
- 支持可插拔的HTTP编码器和解码器。
- 支持Hystrix和它的Fallback。
- 支持Ribbon的负载均衡。
- 支持HTTP请求和响应的压缩。
- List item
工作原理
在主程序入口添加@EnableFeignClients注解,开启对FeignClient扫描加载处理;当程序启动时,会进行包扫描,扫描所有@FeignClients注解的类,并将这些信息注入到Spring IOC容器中,当定义的Feign接口中的方法被调用时,通过JDK的代理的方式,来生成具体的RequestTemplate。当生成代理时,Feign会为每个接口方法创建一个RequestTemplate对象,该对象封装了HTTP请求的需要的全部信息,然后由RequestTemplate生成Request,然后把Request交给Client去处理,这里的Client可以是JDK原生的URLConnection、Apache的HTTP Client,也可以是Okhttp.。最后Client被封装到LoadBalanceClient类,这个类结合Ribbon负载均衡发起服务之间的调用。