Feign的设计原理

Feign是一个声明式的伪Http客户端,它使得写Http客户端变得更容易。使用Feign,只需要创建一个接口并注解。它具有可插拔的注解特性,可使用Feign 注解和JAX-RS注解。Feign支持可插拔的编码器和解码器。Feign默认集成了Ribbon,并和Eureka结合,默认实现了负载均衡的效果。

1、Feign的架构

Feign的架构图如下:

Feign的架构分为四层:

1、API层:定义客户端和服务端之间的接口,接口中的类型和方法,以及参数和返回值,这里可以使用Java的注解来定义,比如@RequestMapping,@RequestParam,@RequestBody等;

2、Contract层:定义了Feign的接口,这里可以指定请求的方法,请求的URL,请求的参数,请求头,以及请求体;

3、Client层:实现了Feign接口,并且封装了HTTP请求;

4、Logging层:提供了日志功能,用于记录Feign的请求日志。

2、Feign的工作原理

Feign的工作原理如下:

1、当客户端调用Feign Client接口时,Feign会根据注解中的信息,将请求转换为HTTP请求;

2、Feign会根据配置的负载均衡策略,选择一个后端服务实例;

3、Feign会将转换后的HTTP请求发送到选择的后端服务实例;

4、后端服务实例处理请求,并将处理结果返回给Feign;

5、Feign将处理结果返回给客户端。

3、Feign的优点

Feign的优点如下:

1、Feign简化了客户端的开发,只需要创建一个接口并注解;

2、Feign支持可插拔的注解特性,可使用Feign 注解和JAX-RS注解;

3、Feign支持可插拔的编码器和解码器;

4、Feign默认集成了Ribbon,并和Eureka结合,默认实现了负载均衡的效果;

5、Feign支持Hystrix的容错,当某个服务出现异常,Feign可以自动进行容错处理。