Feign的日志打印
Feign提供了日志打印功能,我们可以通过配置来调整日志级别,从而了解Feign 中 Http请求的细节。也就是对Feign接口的调用情况进行监控和输出.
日志级别
- NONE:默认的,不显示任何日志;
- BASIC:仅记录请求方法、URL、响应状态码及执行时间;
- HEADERS:除了BASIC中定义的信息之外,还有请求和响应的头信息;
- FULL:除了HEADERS中定义的信息之外,还有请求和响应的正文及元数据。
编写Feign日志配置
package com.gcl.springcloud.config;
import feign.Logger;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
@Configuration
public class FeignConfig {
@Bean
Logger.Level feignLoggerLevel(){
return Logger.Level.FULL;
}
}
在yml中开启Feign的日志
logging:
level:
# feign日志以什么级别监控哪个接口
com.gcl.springcloud.service.FeignService: debug
运行日志
2021-12-09 21:44:12.987 DEBUG 52973 --- [nio-8083-exec-1] c.gcl.springcloud.service.FeignService : [FeignService#getPaymentById] <--- HTTP/1.1 200 (815ms)
2021-12-09 21:44:12.987 DEBUG 52973 --- [nio-8083-exec-1] c.gcl.springcloud.service.FeignService : [FeignService#getPaymentById] connection: keep-alive
2021-12-09 21:44:12.987 DEBUG 52973 --- [nio-8083-exec-1] c.gcl.springcloud.service.FeignService : [FeignService#getPaymentById] content-type: application/json
2021-12-09 21:44:12.987 DEBUG 52973 --- [nio-8083-exec-1] c.gcl.springcloud.service.FeignService : [FeignService#getPaymentById] date: Thu, 09 Dec 2021 13:44:12 GMT
2021-12-09 21:44:12.987 DEBUG 52973 --- [nio-8083-exec-1] c.gcl.springcloud.service.FeignService : [FeignService#getPaymentById] keep-alive: timeout=60
2021-12-09 21:44:12.987 DEBUG 52973 --- [nio-8083-exec-1] c.gcl.springcloud.service.FeignService : [FeignService#getPaymentById] transfer-encoding: chunked
2021-12-09 21:44:12.987 DEBUG 52973 --- [nio-8083-exec-1] c.gcl.springcloud.service.FeignService : [FeignService#getPaymentById]
2021-12-09 21:44:12.990 DEBUG 52973 --- [nio-8083-exec-1] c.gcl.springcloud.service.FeignService : [FeignService#getPaymentById] {"code":200,"message":"查询成功,端口为: 8002","data":{"id":1,"serial":"测试数据"}}
2021-12-09 21:44:12.990 DEBUG 52973 --- [nio-8083-exec-1] c.gcl.springcloud.service.FeignService : [FeignService#getPaymentById] <--- END HTTP (93-byte body)
2021-12-09 21:44:13.564 INFO 52973 --- [erListUpdater-0] c.netflix.config.ChainedDynamicProperty : Flipping property: CLOUD-PAYMENT-SERVICE.ribbon.ActiveConnectionsLimit to use NEXT property: niws.loadbalancer.availabilityFilteringRule.activeConnectionsLimit = 2147483647
Fegin的超时设置
OpenFeign默认等待1秒钟,超过后报错
YML文件里需要开启OpenFeign客户端超时控制
#设置feign客户端超时时间(OpenFeign默认支持ribbon)(单位:毫秒)
ribbon:
#指的是建立连接所用的时间,适用于网络状况正常的情况下,两端连接所用的时间
ReadTimeout: 5000
#指的是建立连接后从服务器读取到可用资源所用的时间
ConnectTimeout: 5000