文章目录
前言
通过yml中设置一些属性,就可以让OpenFeign的功能更加强大,它不仅限于服务间的调用,还有请求重试、压缩等功能。
一、为什么要配置
在所有服务都正常的情况下仅仅使用FeignClient
是没有问题的,但总会是会有各种万一的出现,比如下游服务异常一直请求不通、服务500等等一些问题,所以我们要配置一些属性来应对。
二、配置属性
在进行yml相关配置之前,先加一些代码,保证在测试yml属性时可以看到效果。
1. 代码
import feign.Logger;
import feign.Retryer;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import static java.util.concurrent.TimeUnit.SECONDS;
@Configuration
public class MyFeignConfig {
@Bean
public Retryer myRetryer() {
// 看情况选择一个就行
// return new Retryer.Default();
// return new Retryer.Default(100, SECONDS.toMillis(1), 2); // 1秒内重试3次,时间间隔100毫秒
return Retryer.NEVER_RETRY;
}
@Bean
public Logger.Level feignLoggerLevel() {
return Logger.Level.FULL;
}
}
2. yml配置
2.1 开启Feign日志
针对FeignClient所在的类开启debug日志输出
logging:
level:
com.ukeren.springcloud.feign.api.PaymentServiceFeign: debug
2.2 读取超时和连接超时
default
表示全部服务都用这个配置,如果想要为每个服务都配置一个的话,与default同级别,服务配置会覆盖默认配置
feign:
client:
config:
default:
connectTimeout: 5000
readTimeout: 5000
backend-service-1:
connectTimeout: 1000
readTimeout: 1000
connectTimeout
:避免服务器处理时间过长而阻塞调用方
readTimeout
:避免返回响应时消费太多时间
效果图,如下:
2.3 gzip压缩
feign:
compression:
request:
enabled: true
min-request-size: 2048
mime-types: text/xml,application/xml,application/json
response:
enabled: true
useGzipDecoder: true
未开启压缩的日志输出,如下图
开启压缩的日志输出,如下图
2.4 变更httpclient客户端
启用hc5,比自带的httpclient性能高
feign:
httpclient:
hc5:
enabled: true
3.日志输出说明
开启的debug日志输出,在测试环境下用就可以了,其他环境用不到的话,删掉,或者改为info级别的日志输出
logging:
level:
com.ukeren.springcloud.feign.api.PaymentServiceFeign: info
标签:Retryer,feign,OpenFeign,SpringCloud,配置,重试,import,日志,yml From: https://blog.csdn.net/tsstep/article/details/139578712