feignclient多个配置_@FeignClient同一个name使用多个配置类(详细教程)

@FeignClient无法支持同一service具有多种不同配置的FeignClient,因此,在必要时需要手动build FeignClient

首先创建FeignClientConfigurer类,这个类相当于build FeignClient的工具类

FeignClientConfigurer.java

@Import(FeignClientsConfiguration.class)

public class FeignClientConfigurer {

private Decoder decoder;

private Encoder encoder;

private Client client;

private Contract contract;

private LoadBalancedResourceDetails loadBalancedResourceDetails;

public FeignClientConfigurer(Decoder decoder, Encoder encoder, Client client, Contract contract, LoadBalancedResourceDetails loadBalancedResourceDetails) {

this.decoder = decoder;

this.encoder = encoder;

this.client = client;

this.contract = contract;

this.loadBalancedResourceDetails = loadBalancedResourceDetails;

}

public RequestInterceptor getOAuth2RequestInterceptor() {

return new OAuth2FeignRequestInterceptor(new DefaultOAuth2ClientContext(), loadBalancedResourceDetails);

}

public RequestInterceptor getUserFeignClientInterceptor() {

return new UserFeignClientInterceptor();

}

public T buildAuthorizedFeignClient(Classclazz, String serviceName) {

return getBasicBuilder().requestInterceptor(getOAuth2RequestInterceptor()).target(clazz, buildServiceUrl(serviceName));

}

public T buildAuthorizedUserFeignClient(Classclazz, String serviceName) {

return getBasicBuilder().requestInterceptor(getUserFeignClientInterceptor()).target(clazz, buildServiceUrl(serviceName));

}

private String buildServiceUrl(String serviceName) {

return "http://" + serviceName;

}

protected Feign.Builder getBasicBuilder() {

return Feign.builder().client(client).encoder(encoder).decoder(decoder).contract(contract);

}

}

使用工具类的方法创建多个FeignClient配置

FeignClientConfiguration.java

@Configuration

public class FeignClientConfiguration extends FeignClientConfigurer {

public FeignClientConfiguration(Decoder decoder, Encoder encoder, Client client, Contract contract, LoadBalancedResourceDetails loadBalancedResourceDetails) {

super(decoder, encoder, client, contract, loadBalancedResourceDetails);

}

@Bean

public UaaFeignClient uaaFeignClient() {

return super.buildAuthorizedFeignClient(UaaFeignClient.class, "uaa");

}

@Bean

public QueryUserFeignClient queryUserFeignClient() {

return super.buildAuthorizedUserFeignClient(QueryUserFeignClient.class, "uaa");

}

}

其中,super.buildAuthorizedUserFeignClient()方法中,第一个参数为调用别的服务的接口类,第二个参数为被调用服务在注册中心的service-id。

UaaFeignClient.java

public interface UaaFeignClient {

@RequestMapping(value = "/users", method = RequestMethod.GET)

UserDTO getUser(@RequestParam("userId") String userId);

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Eureka上一个服务有多个实例时,可以通过负载均衡的方式来决定调用哪一个实例。Eureka客户端会定时从Eureka Server获取服务列表,并根据一定的规则选择其中的一台进行调用。这个规则通常是根据负载均衡算法来决定的,常见的负载均衡算法有轮询、随机、加权随机、最少活跃数等。 在Spring Cloud中,可以通过引入负载均衡器实现负载均衡。具体来说,可以在服务消费者中使用`@LoadBalanced`注解标注RestTemplate、FeignClient等相关组件,表示开启负载均衡功能。例如: ``` @LoadBalanced @Bean public RestTemplate restTemplate() { return new RestTemplate(); } ``` 这样在调用服务时,RestTemplate会自动根据负载均衡算法选择其中的一台实例进行请求。如果想要使用FeignClient调用服务,只需要在@FeignClient注解中添加`configuration`属性,指定使用的负载均衡器即可。例如: ``` @FeignClient(name = "service-provider", configuration = FeignConfig.class) public interface UserService { @GetMapping("/user/{id}") User getUserById(@PathVariable("id") Long id); } ``` 其中,`FeignConfig`是一个配置,用于指定FeignClient使用的负载均衡器。例如: ``` @Configuration public class FeignConfig { @Bean public LoadBalancerFeignClient feignClient() { return new LoadBalancerFeignClient(new ApacheHttpClient(), new NoOpServerListSupplier()); } } ``` 在配置中,我们使用了`LoadBalancerFeignClient`作为FeignClient的实现,并禁用了服务列表的自动刷新功能。这样,FeignClient就可以根据负载均衡算法选择其中的一台实例进行请求了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值