微服务的Feign到底是什么

本文涉及的产品
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
简介: Feign是什么分区是一种数据库优化技术,它可以将大表按照一定的规则分成多个小表,从而提高查询和维护的效率。在分区的过程中,数据库会将数据按照分区规则分配到不同的分区中,并且可以在分区中使用索引和其他优化技术来提高查询效率。

Feign是什么

分区是一种数据库优化技术,它可以将大表按照一定的规则分成多个小表,从而提高查询和维护的效率。在分区的过程中,数据库会将数据按照分区规则分配到不同的分区中,并且可以在分区中使用索引和其他优化技术来提高查询效率。


Feign底层实现了Java的动态代理机制,可以根据接口定义动态生成接口的实现类。当客户端通过Feign发起HTTP请求时,Feign会通过动态代理机制把HTTP请求转换成接口方法的调用,同时将方法参数序列化成HTTP请求的参数,并发起HTTP请求。HTTP响应返回后,Feign会将响应反序列化成对应的Java对象,并返回给客户端。


Feign的作用


在Feign中,可以通过注解的方式定义HTTP请求的参数和返回值类型、HTTP请求的URL、HTTP请求的方法等信息。在调用Feign的接口方法时,Feign会根据注解的信息和方法参数构建HTTP请求,并发起HTTP请求。同时,Feign还支持使用自定义的Encoder和Decoder对请求和响应的参数进行序列化和反序列化,方便自定义的HTTP参数格式和协议。


Feign还提供了可扩展的接口和实现类,可以通过继承和实现这些接口和类,实现自定义的HTTP请求和响应的拦截器、错误处理器等功能。例如,可以通过实现RequestInterceptor接口,实现对HTTP请求的拦截和修改,以满足自定义的HTTP协议要求。


Feign的源码结构

Feign的基本源码结构如下:


feign.Feign:Feign的入口类,用于构建Feign客户端;


feign.Request:请求接口,用于定义请求方式、请求头、请求体等信息;


feign.Response:响应接口,用于封装响应结果;


feign.Target:目标接口,用于存储请求的目标信息,例如服务名称、请求路径等;


feign.Contract:契约接口,用于定义请求接口和目标接口之间的关系;


feign.Client:客户端接口,用于定义如何发送请求和接收响应;


feign.codec.Decoder:解码器接口,用于将响应结果解码为Java对象;


feign.codec.Encoder:编码器接口,用于将请求参数编码为请求体;


feign.codec.ErrorDecoder:错误解码器接口,用于将HTTP响应中的错误信息解码为Feign的异常;


feign.Logger:日志接口,用于记录请求和响应的详细信息;


feign.Retryer:重试接口,用于定义请求失败后的重试策略;


feign.Target.HardCodedTarget:目标接口的默认实现类,用于存储目标信息;


feign.Contract.Default:契约接口的默认实现类,用于使用默认的注解方式定义请求接口和目标接口之间的关系;


feign.Client.Default:客户端接口的默认实现类,用于使用java.net.HttpURLConnection发送请求和接收响应;


feign.codec.Decoder.Default:解码器接口的默认实现类,用于使用Jackson将响应结果解码为Java对象;


feign.codec.Encoder.Default:编码器接口的默认实现类,用于将请求参数编码为请求体;


feign.codec.ErrorDecoder.Default:错误解码器接口的默认实现类,用于将HTTP响应中的错误信息解码为Feign的异常;


feign.Logger.JavaLogger:日志接口的默认实现类,用于使用java.util.logging.Logger记录日志;


feign.Retryer.Default:重试接口的默认实现类,用于使用默认的重试策略。


这些组件构成了Feign的基本框架,开发者可以根据实际需求自定义各个组件的实现,从而实现自己的Feign客户端。


这些组件构成了Feign的基本框架,开发者可以根据实际需求自定义各个组件的实现,从而实现自己的Feign客户端。


Feign的内部动态代理


Feign是通过动态代理来生成客户端接口的实现类的。在运行时,Feign会动态生成一个代理对象来实现客户端接口,同时会根据客户端接口中定义的注解来生成相应的HTTP请求,然后通过HTTP客户端发送请求,并将响应映射回客户端接口方法的返回类型。


动态代理是一种在运行时创建代理对象的方式,它不需要事先知道代理对象的类,而是在运行时根据需要创建代理对象。Java中有两种方式可以实现动态代理:基于接口的代理和基于类的代理。


Feign使用的是基于接口的动态代理。它的实现基于Java的反射机制,通过反射获取客户端接口的方法和注解信息,然后动态生成代理对象。代理对象在执行方法时,会通过注解信息生成相应的HTTP请求,并将请求发送给服务器。服务器返回响应后,代理对象会将响应映射到客户端接口方法的返回类型中。


Feign使用了第三方库来实现动态代理,例如JDK自带的java.lang.reflect.Proxy和CGLIB库。在默认情况下,Feign使用的是基于JDK自带Proxy的动态代理实现方式。如果客户端接口中定义的方法没有在接口中声明,或者返回类型是一个具体类而不是接口类型,则需要使用CGLIB库来实现代理对象。


vFeign的拦截器


Feign是通过动态代理来生成客户端接口的实现类的。在运行时,Feign会动态生成一个代理对象来实现客户端接口,同时会根据客户端接口中定义的注解来生成相应的HTTP请求,然后通过HTTP客户端发送请求,并将响应映射回客户端接口方法的返回类型。


动态代理是一种在运行时创建代理对象的方式,它不需要事先知道代理对象的类,而是在运行时根据需要创建代理对象。Java中有两种方式可以实现动态代理:基于接口的代理和基于类的代理。


Feign使用的是基于接口的动态代理。它的实现基于Java的反射机制,通过反射获取客户端接口的方法和注解信息,然后动态生成代理对象。代理对象在执行方法时,会通过注解信息生成相应的HTTP请求,并将请求发送给服务器。服务器返回响应后,代理对象会将响应映射到客户端接口方法的返回类型中。


Feign使用了第三方库来实现动态代理,例如JDK自带的java.lang.reflect.Proxy和CGLIB库。在默认情况下,Feign使用的是基于JDK自带Proxy的动态代理实现方式。如果客户端接口中定义的方法没有在接口中声明,或者返回类型是一个具体类而不是接口类型,则需要使用CGLIB库来实现代理对象。

bfc41663fc4ef7aa762a8931ffc01974.png

在上面的代码中,我们定义了一个 MyResponseInterceptor 类,该类实现了 ResponseInterceptor 接口,并实现了 handleResponse() 方法。在该方法中,我们可以对响应进行自定义的处理,例如打印响应状态码和响应体。


要使用该拦截器,我们需要在 Feign 的构造函数中传入该拦截器的实例,例如:

970dfa8f31ad276ae022b0e301d8062e.png


在上面的代码中,我们将 MyResponseInterceptor 实例传入 Feign.builder() 的 target() 方法中,以便在请求完成后对响应进行拦截和处理。

相关文章
|
17小时前
|
机器学习/深度学习 负载均衡 Java
【SpringBoot系列】微服务远程调用Open Feign深度学习
【4月更文挑战第9天】微服务远程调度open Feign 框架学习
|
17小时前
|
存储 负载均衡 Java
【Spring底层原理高级进阶】微服务 Spring Cloud 的注册发现机制:Eureka 的架构设计、服务注册与发现的实现原理,深入掌握 Ribbon 和 Feign 的用法 ️
【Spring底层原理高级进阶】微服务 Spring Cloud 的注册发现机制:Eureka 的架构设计、服务注册与发现的实现原理,深入掌握 Ribbon 和 Feign 的用法 ️
|
17小时前
|
Java Apache 开发者
【微服务】5、声明式 HTTP 客户端 —— Feign
【微服务】5、声明式 HTTP 客户端 —— Feign
48 0
|
6月前
|
负载均衡 Java Maven
微服务技术系列教程(23) - SpringCloud- 声明式服务调用Feign
微服务技术系列教程(23) - SpringCloud- 声明式服务调用Feign
76 0
|
7月前
|
负载均衡 Dubbo 网络协议
微服务RPC框架:Feign和Dubbo
微服务RPC框架:Feign和Dubbo
326 0
|
7月前
|
负载均衡 Java 开发者
微服务组件 Open Feign 远程调用
OpenFeign是一个声明式的Web服务客户端,它是Spring Cloud生态系统中的一个组件,用于简化和优化微服务之间的远程调用。通过使用注解和接口定义的方式,开发者可以轻松地实现对其他微服务的访问。 使用OpenFeign,您只需定义一个接口,并通过注解来配置该接口对应的远程服务的URL、请求方法、请求参数等信息,OpenFeign将自动生成可用于调用远程服务的实现。这样,您就可以像调用本地方法一样调用远程服务,而无需编写繁琐的HTTP请求和解析代码。
93 0
|
7月前
|
Cloud Native 应用服务中间件 Go
深入解析:探索Nginx与Feign交锋的背后故事 - 如何优雅解决微服务通信中的`301 Moved Permanently`之谜!
深入解析:探索Nginx与Feign交锋的背后故事 - 如何优雅解决微服务通信中的`301 Moved Permanently`之谜!
67 0
|
8月前
|
负载均衡 Java API
解密微服务之Feign
当谈到微服务架构和RESTful API调用时,Feign是一个备受欢迎的工具,它可以简化客户端与服务之间的通信。本文将详细介绍Feign,解释它是什么,为什么它如此重要,以及如何在你的项目中使用它。
|
10月前
|
Java Linux 微服务
Feign的远程调用--微服务重试的坑
Feign的远程调用--微服务重试的坑
277 0
|
10月前
|
JSON 算法 Java
Spring Cloud & Alibaba 实战 | 第十二篇: 微服务整合Sentinel的流控、熔断降级,赋能拥有降级功能的Feign新技能熔断,实现熔断降级双剑合璧(二))(JMeter模拟测试)
Spring Cloud & Alibaba 实战 | 第十二篇: 微服务整合Sentinel的流控、熔断降级,赋能拥有降级功能的Feign新技能熔断,实现熔断降级双剑合璧(JMeter模拟测试)(二)