SpringCloud修改Feign日志记录级别过程浅析
前言
本次示例代码的文件结构如下图所示。

1. 介绍
Feign 允许我们自定义配置,下面是 Feign 可以修改的配置。
| 类型 | 作用 | 说明 |
|---|---|---|
feign.Logger.Level | 修改日志级别 | 包含四种不同级别:NONE、BASIC、HEADERS、FULL |
feign.codec.Decoder | 响应结果的解析器 | HTTP 远程调用的结果做解析,例如解析 JSON 字符串反序列化成 Java 对象 |
feign.codec.Encoder | 请求参数编码 | 将请求参数编码,便于通过 HTTP 请求发送 |
feign.Contract | 支持的注解格式 | 默认是 Spring MVC 的注解 |
feign.Retryer | 失败重试机制 | 请求失败的重试机制,默认是没有,不过会使用 Ribbon 的重试 |
- 一般我们需要配置日志级别。NONE 是不记录,BASIC 只记录基本的 HTTP 请求信息,HEADERS 除了基本的 HTTP 信息外,还记录请求头;而 FULL 则是记录完整的 HTTP 信息。换句话说,按日志完整程度从小到大排序为:NONE < BASIC < HEADERS < FULL 。
- 实际开发中,推荐使用 BASIC 。因为记录日志会消耗一定的性能。
2. 方式一
配置文件
1)全局生效 order-service 的配置文件。
feign:
client:
config:
default: # 全局生效,所有微服务生效
logger-level: FULL
重启 OrderApplication 生效,当在 Postman 发送了一次查询请求后, OrderApplication 的控制台就出现了全部的 HTTP 日志信息。

2)局部生效
feign:
client:
config:
userservice: # 只在远程调用userservice这个微服务时才生效
logger-level: FULL
3. 方式二
Java代码
在 OrderApplication 中创建 Feign 配置类 config/DefaultFeignConfiguration.java ,声明 Bean 。
public class DefaultFeignConfiguration {
@Bean
public Logger.Level loggerLevel() {
return Level.BASIC;
}
}
该类没有被 Spring 容器管理,因此不会生效。还需要进行下面的配置才能生效。
1)全局配置
在启动类的 @EnableFeignClients 注解上添加参数,指定 Feign 的配置类。
@EnableFeignClients(defaultConfiguration = DefaultFeignConfiguration.class)
2)局部配置
放到 Feign 客户端接口的注解 @FeignClient 之中。
@FeignClient(value = "userservice", configuration = DefaultFeignConfiguration.class)
到此这篇关于SpringCloud修改Feign日志记录级别过程浅析的文章就介绍到这了,更多相关SpringCloud修改Feign日志内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
- SpringCloud Hystrix熔断器使用方法介绍
- SpringCloud Gateway动态路由配置详解
- Spring Cloud Gateway远程命令执行漏洞分析(CVE-2022-22947)
- SpringSecurit盐值加密的密码验证以及强密码验证过程
- Spring Cloud Alibaba实现服务的无损下线功能(案例讲解)
- springcloud-gateway集成knife4j的示例详解
- SpringCloud Alibaba环境集成之nacos详解
- Spring Cloud Ribbon 负载均衡使用策略示例详解
- SpringCloud @RefreshScope刷新机制深入探究
- SpringCloud @RefreshScope刷新机制浅析
- SpringCloud启动失败问题汇总
- 一文吃透Spring Cloud gateway自定义错误处理Handler
- SpringCloud Gateway路由组件详解
- SpringCloud OpenFeign基本介绍与实现示例
- Spring Cloud Gateway替代zuul作为API网关的方法
- SpringCloud使用Feign实现远程调用流程详细介绍
- SpringCloud开启session共享并存储到Redis的实现
- Spring Cloud原理以及核心组件详解
相关文章
Springboot如何设置过滤器及重复读取request里的body
这篇文章主要介绍了Springboot如何设置过滤器及重复读取request里的body,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2022-03-03


最新评论