Feign源码深度刨析-(3)核心组件:FeignClientFactoryBean(上)

“不积跬步,无以至千里。”

前面说了,@EnableFeignClients 这个注解往容器中导入了一个组件 FeignClientsRegistrar ,这个组件实现了 ImportBeanDefinitionRegistrar接口,那么它的 registerBeanDefinitions() 方法就会往spring容器中导入一些组件

registerFeignClients(metadata, registry);

这个方法会搞一个组件扫描器ClassPathScanningCandidateComponentProvider,专门扫描我们自己写的Feign客户端的接口,即添加了@FeignClient注解的接口

扫描之后,会放进一个Set集合中,然后遍历这个集合,依次调用registerFeignClient()方法将其注册到spring容器中

private void registerFeignClient(BeanDefinitionRegistry registry,
                                 AnnotationMetadata annotationMetadata, Map<String, Object> attributes) {
   
   
    String className = annotationMetadata.getClassName();
    BeanDefinitionBuilder definition = BeanDefinitionBuilder
        .genericBeanDefinition(FeignClientFactoryBean.class);
    validate(attributes);
    definition.addPropertyValue("url", getUrl(attributes));
    definition.addPropertyValue("path", getPath(attributes));
    String name = getName(attributes);
    definition.addPropertyValue("name", name);
    definition.addPropertyValue("type", className);
    definition.addPropertyValue("decode404", attributes.get("decode404"));
    definition.addPropertyValue("fallback", attributes.get("fallback"));
    definition.addPropertyValue("fallbackFactory", attributes.get("fallbackFactory"));
    definition.setAutowireMode(AbstractBeanDefinition.AUTOWIRE_BY_TYPE);

    String alias = name + "FeignClient";
    AbstractBeanDefinition beanDefinition = definition.getBeanDefinition();

    boolean primary = (Boolean)attributes.get("primary"); // has a default, won't be null

    beanDefinition.setPrimary(primary);

    String qualifier = getQualifier(attributes);
    if (StringUtils.hasText
### 查看 ${feign.busiplat-url:} 值的方法 在 Spring Cloud 项目里,像 ${feign.busiplat-url:} 这样的占位符配置值,通常可在以下位置查看: - **配置文件**:Spring Boot 项目中,常见的配置文件有 `application.properties` 或者 `application.yml`。 - **application.properties** ```properties feign.busiplat-url=http://example.com ``` - **application.yml** ```yaml feign: busiplat-url: http://example.com ``` - **环境变量**:可以通过设置环境变量来覆盖配置文件中的值。在运行项目时,可以通过 `-D` 参数或者操作系统的环境变量来设置。 ```bash java -Dfeign.busiplat-url=http://example.com -jar your-application.jar ``` - **配置中心**:如果项目使用了配置中心(如 Nacos、Config Server 等),配置信息会集中存储在配置中心。需要登录配置中心的管理界面,找到对应的配置文件,查看 `feign.busiplat-url` 的值。 - **代码中的配置类**:有时候,配置信息可能会在代码中的配置类里进行设置。可以检查项目中是否有相关的配置类,查看是否有对 `feign.busiplat-url` 的设置。 ```java import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import org.springframework.core.env.Environment; @Configuration public class FeignConfig { private final Environment environment; public FeignConfig(Environment environment) { this.environment = environment; } @Bean public String busiplatUrl() { return environment.getProperty("feign.busiplat-url", "default-url"); } } ``` ### feign 配置项 usercenter-service、orgcenter-service、configcenter-base-service 的含义和使用说明 - **含义**:这些配置项通常代表不同的服务名。在微服务架构中,每个服务都有自己的名称,`usercenter-service` 可能是用户中心服务,负责处理用户相关的业务逻辑;`orgcenter-service` 可能是组织中心服务,用于管理组织架构信息;`configcenter-base-service` 可能是配置中心基础服务,负责管理和提供系统的配置信息。 - **使用方式**:在 `@FeignClient` 注解中使用这些服务名来指定要调用的服务。例如: ```java import org.springframework.cloud.openfeign.FeignClient; import org.springframework.web.bind.annotation.GetMapping; @FeignClient(name = "usercenter-service") public interface UserCenterClient { @GetMapping("/user/info") String getUserInfo(); } ``` 在上述代码中,`@FeignClient(name = "usercenter-service")` 指定了要调用的服务名为 `usercenter-service` 的服务,`getUserInfo` 方法对应了该服务中的 `/user/info` 接口。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值