当前位置:主页 > java教程 > SpringBoot项目集成日志的方法

SpringBoot项目集成日志的方法步骤

发布:2019-06-18 09:46:53 109


本站精选了一篇相关的编程文章,网友万成美根据主题投稿了本篇教程内容,涉及到SpringBoot、集成日志、SpringBoot项目集成日志的方法相关内容,已被273网友关注,下面的电子资料对本篇知识点有更加详尽的解释。

SpringBoot项目集成日志的方法

SpringBoot使用Commons Logging进行所有内部日志记录,但保留底层日志实现。默认提供了Java Util Logging, Log4j2 和Logback日志配置。在每种情况下,都预先配置为使用控制台输出,并且还提供了可选的文件输出。(来自官网)

SpringBoot项目集成日志的实现方法

日志格式

SpringBoot默认的日志输出如下所示:

2014-03-05 10:57:51.112 INFO 45469 --- [   main] org.apache.catalina.core.StandardEngine : Starting Servlet Engine: Apache Tomcat/7.0.52
2014-03-05 10:57:51.253 INFO 45469 --- [ost-startStop-1] o.a.c.c.C.[Tomcat].[localhost].[/]  : Initializing Spring embedded WebApplicationContext
2014-03-05 10:57:51.253 INFO 45469 --- [ost-startStop-1] o.s.web.context.ContextLoader   : Root WebApplicationContext: initialization completed in 1358 ms
2014-03-05 10:57:51.698 INFO 45469 --- [ost-startStop-1] o.s.b.c.e.ServletRegistrationBean  : Mapping servlet: 'dispatcherServlet' to [/]
2014-03-05 10:57:51.702 INFO 45469 --- [ost-startStop-1] o.s.b.c.embedded.FilterRegistrationBean : Mapping filter: 'hiddenHttpMethodFilter' to: [/*]

输出以下项目:

  • 日期和时间:毫秒精度并且容易排序
  • 日志级别:ERROR, WARN, INFO, DEBUG, TRACE
  • 进程ID
  • --- 分隔符来区分实际日志的开始
  • 线程名:括在方括号中(可能会被截断)
  • 日志记录器名:这通常是源类名(通常缩写)
  • 日志信息

Logback中没有FATAL(致命)级别,它被映射到ERROR级别

日志格式 来自 官网 )

控制台输出

SpringBoot控制台输出默认支持三种日志级别:ERROR,WARN和INFO

如果还想输出别的级别日志,例如DEBUG或TRACE(只能二选一),如下操作:

启动应用程序时,增加--debug或--trace标志

$ java -jar myapp.jar -- debug

说明:使用debug调试模式启动应用程序不会将应用程序配置为使用DEBUG级别记录日志。复制代码

在application.yml中(或application.properties中)增加debug: true或trace: true(或debug=true/trace=true)

application.yml文件:

debug: true

application.properties文件:

debug=true

多彩输出:

如果终端支持ANSI(表示颜色),可以设置彩色输出。

application.yml中设置:

# 检查终端是否支持ANSI,是的话就采用彩色输出
spring:
 output:
 ansi:
  enabled: detect

application.properties中设置:

# 检查终端是否支持ANSI,是的话就采用彩色输出
spring.output.ansi.enabled=detect

文件输出

SpringBoot默认配置日志只会输出到控制台,并不会记录到文件中,但通常生产环境需要把日志记录到文件中。

配置属性如下:

  • logging.file: 设置日志输出文件,绝对路径或相对路径都可以。
  • logging.path: 设置日志输出目录,会在该目录下创建spring.log文件,并写入日志内容。

日志文件在达到10 MB时滚动输出,并且与控制台输出一样,默认情况下会记录ERROR,WARN和INFO级别的日志。可以使用logging.file.max-size属性更改大小限制。除非已设置logging.file.max-history属性,否则以前轮换的日志文件将被无限期归档。(来自官网)

注意点:

日志记录系统在应用程序生命周期的早期初始化。因此,在通过@PropertySource注解加载的属性文件中找不到日志记录属性。

日志记录属性独立于实际的日志记录基础结构。因此,SpringBoot不管理特定的配置密钥(例如Logback的logback.configurationFile)。 (来自官网)

application.yml中设置:

logging:
 # 设置相对路径的日志输出文件
 file: log/my.log
 # 设置日志输出路径,默认会生成log/spring.log日志文件
 path: log
 
logging:
 # 设置绝对路径的日志输出文件
 file: D:\ideaProjects\SpringBootDemo\log1\mylog1.log
 # 设置日志输出路径,默认会生成log/spring.log日志文件
 path: log

application.properties中设置:

logging.file=log/my.log
logging.path=log

SpringBoot项目集成日志的实现方法

级别控制

配置属性格式:logging.level.*=LEVEL

  • logging.level: 日志级别控制前缀,*为包名或Logger名
  • LEVEL: 选项TRACE, DEBUG, INFO, WARN, ERROR, FATAL, OFF

application.yml中设置:

logging:
 level:
 # com.example.demo包下所有class以DEBUG级别输出
 com.example.demo: DEBUG
 # root日志以INFO级别输出
 root: INFO

说明:
配置日志级别值大小写均可,例如:设置成debug/info

application.properties中设置:

logging.level.com.example.demo=DEBUG
logging.level.root=INFO

说明:配置日志级别值大小写均可,例如:设置成debug/info

刨根问底,死磕自己(选看)

1. 日志级别设置选项

源码中系统日志级别是个枚举类,列出了所有日志级别,如下截图:

SpringBoot项目集成日志的实现方法

根据在application.yml中设置的LEVEL值,匹配系统日志枚举类,最终设置系统相应包下的日志级别。

SpringBoot项目集成日志的实现方法

SpringBoot官网: https://docs.spring.io/spring-boot/docs/2.1.2.RELEASE/reference/htmlsingle/


参考资料

相关文章

  • Springboot Vue可配置调度任务实现示例详解

    发布:2023-03-01

    这篇文章主要为大家介绍了Springboot Vue可配置调度任务实现示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪


  • SpringBoot使用AOP与注解实现请求参数自动填充流程详解

    发布:2023-04-13

    面向切面编程(aspect-oriented programming,AOP)主要实现的目的是针对业务处理过程中的切面进行提取,诸如日志、事务管理和安全这样的系统服务,从而使得业务逻辑各部分之间的耦合度降低,提高程序的可重用性,同时提高了开发的效率


  • Spring Boot利用Docker快速部署项目的完整步骤

    Spring Boot利用Docker快速部署项目的完整步骤

    发布:2022-10-17

    给大家整理了关于Spring Boot的教程,这篇文章主要给大家介绍了关于Spring Boot利用Docker快速部署项目的完整步骤,文中通过示例代码介绍的非常详细,对大家学习或者使用Spring Boot具有一定的参考学习价值,需要的朋友们下面来一


  • Springboot设置默认访问路径方法实现

    发布:2023-01-24

    为网友们分享了关于Springboot的教程,这篇文章主要介绍了Springboot设置默认访问路径方法实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧


  • SpringBoot中实现跨域的5种方式小结

    SpringBoot中实现跨域的5种方式小结

    发布:2023-01-24

    给网友们整理关于SpringBoot的教程,这篇文章主要介绍了SpringBoot 中实现跨域的5种方式小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧


  • 实例详解springBoot整合CXF并实现用户名密码校验的方法

    发布:2020-02-05

    这篇文章主要介绍了springBoot整合CXF并实现用户名密码校验的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧


  • SpringTask实现定时任务方法讲解

    发布:2023-04-02

    通过重写Schedu lingConfigurer方法实现对定时任务的操作,单次执行、停止、启动三个主要的基本功能,动态的从数据库中获取配置的定时任务cron信息,通过反射的方式灵活定位到具体的类与方法中


  • SpringBoot注册FilterRegistrationBean相关情况讲解

    发布:2023-04-16

    这篇文章主要介绍了SpringBoot注册FilterRegistrationBean相关情况,借助FilterRegistrationBean来注册filter,可以避免在web.xml种配置filter这种原始的写法


网友讨论