服务器之家:专注于服务器技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|JavaScript|易语言|

服务器之家 - 编程语言 - Java教程 - 动态配置Spring Boot日志级别的全步骤

动态配置Spring Boot日志级别的全步骤

2021-08-01 12:07细品热咖啡 Java教程

这篇文章主要给大家介绍了关于动态配置Spring Boot日志级别的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用Spring Boot具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧

前言

项目使用了springboot构建项目。下面对动态调整日志级别进行记录。

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

actuator 依赖

pom 依赖

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

?
1
2
3
4
5
6
7
8
9
<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。为了方便首先配置不需要安全权限的。

?
1
management.security.enabled=false

get 请求访问

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

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
{
 levels: [
 "off",
 "fatal",
 "error",
 "warn",
 "info",
 "debug",
 "trace"
 ],
 loggers: {
 root: {
 configuredlevel: "info",
 effectivelevel: "info"
 },
 com.mall.goods.zhongkui: {
 configuredlevel: "debug",
 effectivelevel: "debug"
 },
 com.mall.goods.zhongkui.mallcpswomai.mapper: {
 configuredlevel: "debug",
 effectivelevel: "debug"
 }
 }
}

配置日志级别

编写日志输出类

编写一个controller 输出各个级别的日志:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
@slf4j
@controller
public class testcontroller {
  
 @getmapping(value = "/testlog")
 public string testlog() {
  log.info("---------------------------");
  log.debug("debug debug");
  log.info("info info info");
  log.warn("warn warn warn");
  log.error("error error error ");
  log.info("---------------------------");
  return "ok";
 }
}

查看日志级别

启动应用访问 http://localhost:8091/ 得到:

[2018-07-30 18:05:42.868] [http-nio-8091-exec-2] info  com.mall.goods.zhongkui.mallcpswomai.web.orderrelationcontroller----------------------------
[2018-07-30 18:05:42.869] [http-nio-8091-exec-2] debug com.mall.goods.zhongkui.mallcpswomai.web.orderrelationcontroller-debug debug
[2018-07-30 18:05:42.869] [http-nio-8091-exec-2] info  com.mall.goods.zhongkui.mallcpswomai.web.orderrelationcontroller-info info info
[2018-07-30 18:05:42.869] [http-nio-8091-exec-2] warn  com.mall.goods.zhongkui.mallcpswomai.web.orderrelationcontroller-warn warn warn
[2018-07-30 18:05:42.869] [http-nio-8091-exec-2] error com.mall.goods.zhongkui.mallcpswomai.web.orderrelationcontroller-error error error
[2018-07-30 18:05:42.869] [http-nio-8091-exec-2] info  com.mall.goods.zhongkui.mallcpswomai.web.orderrelationcontroller----------------------------

spring boot 默认的 root 日志级别是info。

配置特定包的日志级别

通过 /loggers 端点提供的 post 请求,修改包路径com.mall.goods.zhongkui 的日志级别为info。 

 * 发送post 请求到  http://localhost:8091/com.mall.goods.zhongkui,其中请求 body 的内容如下:

?
1
2
3
{
 "configuredlevel": "info"
}

•get 访问 /loggers/com.mall.goods.zhongkui 查看当前的日志级别:

?
1
2
3
4
{
 configuredlevel: "info",
 effectivelevel: "info"
}

•再次访问 http://localhost:8091/ 得到:需要注意的是,通过 /loggers 配置的日志级别在应用重启时会恢复到系统的配置。如果想永久的配置日志的级别还是需要通过logging.level.package-path 来进行配置。

总结

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

参考

1.configure a logger

好了,以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对服务器之家的支持。

原文链接:https://blog.csdn.net/u014684364/article/details/81289696

延伸 · 阅读

精彩推荐
  • Java教程JavaMe开发自适应滚动显示

    JavaMe开发自适应滚动显示

    我们常看到一些滚动显示的实例,比如UC浏览器中,显示网页的内容。当内容比较多时,采用滚动分页显示是合理的。在Canvas中绘图中,多余的内容被截断...

    lijiao1972020-01-06
  • Java教程SpringBoot之返回json数据的实现方法

    SpringBoot之返回json数据的实现方法

    这篇文章主要介绍了SpringBoot之返回json数据的实现方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧...

    张昊亮8212021-06-22
  • Java教程Netty粘包拆包问题解决方案

    Netty粘包拆包问题解决方案

    这篇文章主要介绍了Netty粘包拆包问题解决方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下...

    猿天地4212020-08-13
  • Java教程Spring MVC参数自动绑定List的解决方法

    Spring MVC参数自动绑定List的解决方法

    这篇文章主要为大家详细介绍了Spring MVC参数自动绑定List的解决方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    weechang6562021-03-02
  • Java教程简单理解Java的垃圾回收机制与finalize方法的作用

    简单理解Java的垃圾回收机制与finalize方法的作用

    这篇文章主要介绍了简单理解Java的垃圾回收机制与finalize方法的作用,着重讲解了Java的GC销毁对象的过程,需要的朋友可以参考下 ...

    边缘元素1532020-01-20
  • Java教程java控制台输出数字金字塔示例分享

    java控制台输出数字金字塔示例分享

    这篇文章主要介绍了java控制台输出数字金字塔的示例,控制台输出的缺陷是数字不能完全居中,只能右对齐或左对齐,大家参考使用吧 ...

    java教程网6242019-11-03
  • Java教程基于maven install 没反应的解决方法

    基于maven install 没反应的解决方法

    下面小编就为大家带来一篇基于maven install 没反应的解决方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧...

    Java教程网2742020-11-04
  • Java教程详解SpringCloudGateway内存泄漏问题

    详解SpringCloudGateway内存泄漏问题

    这篇文章主要介绍了详解SpringCloudGateway内存泄漏问题,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们...

    如果悲伤有颜色,那么一8842020-07-17