0


springcloud之feign使用

Feign
feign是声明式的web service客户端,它让微服务之间的调用变得更简单了,类似controller调用service。Spring Cloud集成了Ribbon和Eureka,可在使用Feign时提供负载均衡的http客户端。

使用gradle进行引入feign

  1. dependencies {//feignimplementation('org.springframework.cloud:spring-cloud-starter-openfeign:2.0.2.RELEASE')//webimplementation('org.springframework.boot:spring-boot-starter-web')//eureka clientimplementation('org.springframework.cloud:spring-cloud-starter-netflix-eureka-client:2.1.0.M1')//testtestImplementation('org.springframework.boot:spring-boot-starter-test')}

feign底层是使用了ribbon作为负载均衡的客户端,而ribbon的负载均衡也是依赖于eureka 获得各个服务的地址,所以要引入eureka-client。

SpringbootApplication启动类加上@FeignClient注解,以及@EnableDiscoveryClient。

  1. @SpringBootApplication(exclude ={DataSourceAutoConfiguration.class,PageHelperAutoConfiguration.class})@EnableAsync@EnableTransactionManagement@EnableEurekaClient@EnableHystrix@EnableFeignClients@Slf4jpublicclassNftWebApplication{publicstaticvoidmain(String[] args){SpringApplication.run(NftWebApplication.class, args);
  2. log.info("(♥◠‿◠)ノ゙ NftWeb服务启动成功 ლ(´ڡ`ლ)゙ \n");}}

yaml配置:

  1. server:
  2. port:8082
  3. #配置eureka
  4. eureka:
  5. client:
  6. service-url:
  7. defaultZone: http://localhost:8761/eureka
  8. instance:
  9. status-page-url-path:/info
  10. health-check-url-path:/health
  11. #服务名称
  12. spring:
  13. application:
  14. name: product
  15. profiles:
  16. active: ${boot.profile:dev}
  17. #feign的配置,连接超时及读取超时配置
  18. feign:
  19. client:
  20. config:default:
  21. connectTimeout:5000
  22. readTimeout:5000
  23. loggerLevel: basic

配置好以后,接下来我们进行feign的使用

  1. @FeignClient(value ="CART")publicinterfaceCartFeignClient{@PostMapping("/cart/{productId}")LongaddCart(@PathVariable("productId")Long productId);}

声明完为feign client后,其他spring管理的类,如service就可以直接注入使用了,如下代码:

  1. //这里直接注入feign client@AutowiredprivateCartFeignClient cartFeignClient;@PostMapping("/toCart/{productId}")publicResponseEntityaddCart(@PathVariable("productId")Long productId){Long result = cartFeignClient.addCart(productId);returnResponseEntity.ok(result);}

使用feign之后,我们调用eureka 注册的其他服务,在代码中就像各个service之间相互调用那么简单。

FeignClient注解的一些属性
请添加图片描述

Feign自定义处理返回的异常,自定义好异常处理类后,要在@Configuration修饰的配置类中声明此类。

  1. publicclassStashErrorDecoderimplementsErrorDecoder{@OverridepublicExceptiondecode(String methodKey,Response response){if(response.status()>=400&& response.status()<=499){//这里是给出的自定义异常returnnewStashClientException(
  2. response.status(),
  3. response.reason());}if(response.status()>=500&& response.status()<=599){//这里是给出的自定义异常returnnewStashServerException(
  4. response.status(),
  5. response.reason());}//这里是其他状态码处理方法returnerrorStatus(methodKey, response);}}

Feign原理简述
1.启动时,程序会进行包扫描,扫描所有包下所有@FeignClient注解的类,并将这些类注入到spring的IOC容器中。当定义的Feign中的接口被调用时,通过JDK的动态代理来生成RequestTemplate。
2.RequestTemplate中包含请求的所有信息,如请求参数,请求URL等。
3.RequestTemplate声场Request,然后将Request交给client处理,这个client默认是JDK的HTTPUrlConnection,也可以是OKhttp、Apache的HTTPClient等。
4.最后client封装成LoadBaLanceClient,结合ribbon负载均衡地发起调用。

为提高通信效率,Feign开启GZIP压缩
application.yml配置信息如下:

  1. feign:
  2. compression:
  3. request: #请求
  4. enabled:true #开启
  5. mime-types: text/xml,application/xml,application/json #开启支持压缩的MIME TYPE
  6. min-request-size:2048 #配置压缩数据大小的下限
  7. response: #响应
  8. enabled:true #开启响应GZIP压缩

特别注意:

由于开启GZIP压缩之后,Feign之间的调用数据通过二进制协议进行传输,返回值需要修改为ResponseEntity<byte[]>才可以正常显示,否则会导致服务之间的调用乱码。

eg:

  1. @PostMapping("/order/{productId}")ResponseEntity<byte[]>addCart(@PathVariable("productId")Long productId);

作用在所有Feign Client上的配置方式
方式一:通过java bean 的方式指定。

@EnableFeignClients注解上有个defaultConfiguration属性,可以指定默认Feign Client的一些配置。

  1. @EnableFeignClients(defaultConfiguration =DefaultFeignConfiguration.class)@EnableDiscoveryClient@SpringBootApplication@EnableCircuitBreakerpublicclassProductApplication{publicstaticvoidmain(String[] args){SpringApplication.run(ProductApplication.class, args);}}

DefaultFeignConfiguration内容:

  1. @ConfigurationpublicclassDefaultFeignConfiguration{@BeanpublicRetryerfeignRetryer(){returnnewRetryer.Default(1000,3000,3);}}

方式二:通过配置文件方式指定。

  1. feign:
  2. client:
  3. config:default:
  4. connectTimeout:5000 #连接超时
  5. readTimeout:5000 #读取超时
  6. loggerLevel: basic #日志等级

本文转载自: https://blog.csdn.net/leaning_java/article/details/126656879
版权归原作者 @卓越俊逸_角立杰出@ 所有, 如有侵权,请联系我们删除。

“springcloud之feign使用”的评论:

还没有评论