OpenFeign 提供了一种声明式的远程调用接口,它可以大幅简化远程调用的编程体验。调用其他服务接口像调用本地服务service方法一样丝滑顺畅。
核心
@FeignClient(name = "${xxx}", path = "/api/xxx/xxx")
@EnableFeignClients(basePackages = "com.xxx.xxx")
OpenFeign 使用了动态代理技术来封装远程服务调用的过程。
当我们项目启动时,会通过@EnableFeignClients(basePackages = "com.xxx.xxx")扫描相应包路径下的feignClient,然后使用动态代理技术生成代理类注入到spring容器之中,这样当我们使用feign接口方法发起远程调用,其实就是使用生成的动态代理类去实现请求。
工作流程:
1.主程序启动扫描@EnableFeignClients注解,根据basepackage扫描所有@FeignCleint注解的接口,生成FeignClientFactoryBean,通过getObject方法来获取@FeignClient注解的接口对应的代理对象,注入Spring容器。
2.Feign默认的调用处理器FeignInvocationHandler内部保持了一个远程调用方法实例和方法处理器的一个Key-Value键值对Map映射。在其invoke()方法中,会根据Java反射的方法实例,在dispatch 映射对象中找到对应的 MethodHandler 方法处理器,然后由后者完成实际的HTTP请求和结果的处理。
3.Feign默认的方法处理器为 SynchronousMethodHandler,其invoke()方法主要是通过内部成员feign客户端成员client,完成远程URL请求执行和获取远程结果。feign.Client 客户端有多种类型(HttpClient、OkHttp、HttpURLConnection),不同的类型完成URL请求处理的具体方式不同