SpringBoot实用小技巧之如何动态设置日志级别

作者:欢醉 时间:2023-02-09 04:27:58 

前言

有时线上问题我们用打日志的方式来观察错误或埋点参数,但由于这些日志如果都打出来会占用大量存储空间而且覆盖了一些有效信息,所以线上级别一般设置INFO,调试级别用作特殊情况下。此时如果线上想查看调试级别下的日志,又不能更改日志级别后重新发布该怎么办?

Spring Boot提供了日志级别动态配置功能,为我们的线上应用调试提供了很好的机制。在实际使用中需要结合Spring-Security提供的安全机制来保护Actuator 提供的各种系统级端点的安全访问。

SpringBoot从版本 1.5.1 之后就提供了基于 spring-boot-starter-actuator 的端点 /loggers。通过该端点可以实现查看系统的 package-path 的日志级别,以及针对特定的 package-path 配置运行中的应用的日志级别的功能。

下面对动态调整日志的级别进行设置。

先引入Actuator依赖

因为是基于 Web 的项目和利用 Actuator 提供的端点来进行配置,因此需要依赖:


<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>

<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>

安全配置

Actuator 提供的端点(Endpoints),默认是需要安全认证才能够被访问的。因为里面涉及到一些敏感的信息。需要安全认证就需要配置 Spring-Security。为了方便首先配置不需要安全权限的。

在配置中设置 management.security.enabled=false

GET 请求访问

我们可以发送GET 请求到 http://localhost:8080/loggers 来获取支持的日志等级,以及系统(ROOT)默认的日志等和各个包路径(com.xxx.commond等)对应的日志级别。

访问会返回所有的类的日志级别信息。

SpringBoot实用小技巧之如何动态设置日志级别

配置特定包的日志级别

通过 /loggers 端点提供的 POST 请求,修改包路径com.xxx.commond的日志级别为DEBUG:

发送POST 请求到  http://localhost:8080/loggers/com.xxx.commond,其中请求 Body 的内容如下:


{
"configuredLevel": "DEBUG"
}

再用GET 访问 http://localhost:8080/loggers/com.xxx.commond查看当前的日志级别:


{
configuredLevel: "DEBUG",
effectiveLevel: "INFO"
}

注意:

通过 /loggers 配置的日志级别在应用重启时会恢复到系统的配置,如果想永久的配置日志的级别还是需要通过logging.level.package-path 来进行配置。

第二种方法就比较简单了,如果你有Actuator作了服务端监控,则可以直接访问此监控服务,然后进入具体要调整日志级别的服务进入Logging,直接进行点击设置即可,非常方便,其实内部帮你做了跟上面一样的请求。

SpringBoot实用小技巧之如何动态设置日志级别

这样就可以动态的设置调试程序了,而不用重启服务,是不是非常方便。

部分内容引用参见:https://www.jb51.net/article/159805.htm

来源:http://www.cnblogs.com/zhangs1986/p/10608995.html

标签:springboot,日志,级别
0
投稿

猜你喜欢

  • Java中的final关键字使用方式

    2023-01-16 15:04:25
  • Android 按后退键退出Android程序的实现方法

    2023-06-16 20:08:02
  • Spring @ComponentScan注解扫描组件原理

    2021-09-21 09:10:02
  • C# 中将数值型数据转换为字节数组的方法

    2023-09-29 05:46:17
  • @CacheEvict 清除多个key的实现方式

    2023-11-21 08:28:04
  • 聊聊@RequestMapping和@GetMapping @PostMapping的区别

    2021-07-26 19:20:43
  • SpringBoot配置及使用Schedule过程解析

    2021-12-31 18:47:32
  • SpringBoot请求处理之常用参数注解介绍与源码分析

    2023-11-10 10:38:12
  • Android实现多级树形菜单并支持多选功能

    2023-08-29 20:01:04
  • springboot整合Shiro

    2022-11-13 11:07:52
  • Android中使用Toast.cancel()方法优化toast内容显示的解决方法

    2021-12-14 05:17:03
  • 详解Java8中Optional的常见用法

    2022-04-30 14:32:21
  • c#中LINQ的基本用法(二)

    2022-05-29 07:00:43
  • Android实现简单点赞动画

    2021-05-25 11:12:20
  • Java设计模式--代理模式

    2023-02-26 21:45:32
  • Java按时间梯度实现异步回调接口的方法

    2023-11-09 10:30:29
  • Java GZip 基于内存实现压缩和解压的方法

    2023-05-24 12:47:29
  • 详解C语言实现猜数字游戏

    2023-11-03 04:58:51
  • C#去除字符串中的反斜杠实例(推荐)

    2022-02-02 20:27:14
  • Android实现仿360桌面悬浮清理内存

    2021-08-25 11:21:05
  • asp之家 软件编程 m.aspxhome.com