说明
在上篇博文《OpenFeign学习(七):Spring Cloud OpenFeign的使用》中,我介绍了Spring Cloud OpenFeign的简单用法。在本篇博文中,我将继续对Spring Cloud OpenFeign进行学习,通过源码介绍Spring Cloud是如何对OpenFeign进行集成支持,如何进行加载配置。
正文
注解的使用
在阅读源码前,我们先通过文档简单了解下Spring对OpenFeign进行了那些扩展支持:
Spring Cloud adds support for Spring MVC annotations and for using the same HttpMessageConverters used by default in Spring Web. Spring Cloud integrates Ribbon and Eureka, as well as Spring Cloud LoadBalancer to provide a load-balanced http client when using Feign.
可以看到,Spring Cloud对OpenFeign添加了Spring MVC 注解,与Spring Web相同的HttpMessageConverters,以及集成了Ribbon, Eureka 和 Spring Cloud LoadBalancer。
接下来,我们通过阅读源码来了解Spring Cloud OpenFeignhi如何进行加载配置的:
在之前的使用介绍中,我们主要用了以下两个注解:
- 在启动类上使用@EnableFeignClients注解
@EnableDiscoveryClient
@EnableFeignClients
@SpringBootApplication
public class Feign2ClientApplication {
public static void main(String[] args) {
SpringApplication.run(Feign2ClientApplication.class, args);
}
}
- 在服务接口类上使用@FeignClient注解
@FeignClient(value = "feign2")
public interface Feign2Service {
}
在@EnableFeignClients注解中通过@Import注解将FeignClientsRegistrar类导入容器,并且通过该注解可以配置FeignClient的默认配置,扫描基础包等。
@Retention(RetentionPolicy.RUNTIME)
@Target({ElementType.TYPE})
@Documented
@Import({FeignClientsRegistrar.class})
public @interface EnableFeignClients {
String[] value() default {};
String[] basePackages() default {};
Class<?>[] basePackageClasses() default {};
Class<?>[] defaultConfiguration() default {};
Class<?>[] clients() default {};
}
通过@FeignClient注解来配置对应服务客户端,该注解只能作用于接口类上,也可以通过该注解对客户端进行个性化配置,客户端名称,配置类,调用url等。
@Target({ElementType.TYPE})
@Retention(RetentionPolicy.RUNTIME)
@Documented
public @interface FeignClient {
@AliasFor("name")
String value() default "";
/** @deprecated */
@Deprecated
String serviceId() default "";
String contextId() default "";
@AliasFor("value")
String name() default "";
String qualifier() default "";
String url() default "";
boolean decode404() default false;
Class<?>[] configuration() default {};
Class<?> fallback() default void.class;
Class<?>