SpringBoot项目集成日志的实现方法
作者:让蛋蛋飞 发布时间:2023-06-02 23:00:23
SpringBoot使用Commons Logging进行所有内部日志记录,但保留底层日志实现。默认提供了Java Util Logging, Log4j2 和Logback日志配置。在每种情况下,都预先配置为使用控制台输出,并且还提供了可选的文件输出。(来自官网)
日志格式
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
级别控制
配置属性格式: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. 日志级别设置选项
源码中系统日志级别是个枚举类,列出了所有日志级别,如下截图:
根据在application.yml中设置的LEVEL值,匹配系统日志枚举类,最终设置系统相应包下的日志级别。
SpringBoot官网: https://docs.spring.io/spring-boot/docs/2.1.2.RELEASE/reference/htmlsingle/
来源:https://juejin.im/post/5c525fac51882525800544b4
猜你喜欢
- 本文实例为大家分享了Unity实现俄罗斯方块第3部分,供大家参考,具体内容如下解决穿透问题逻辑部分1、在物体进行移动的过程中更新格子的信息,
- 为什么需要Spring MVC最开始接触网页的时候,是纯的html/css页面,那个时候还是用Dreamweaver来绘制页面。随着网站开发
- 大家好,今天尝试用swing技术写一个贪吃蛇大作战小游戏,供大家参考。 效果展示效果展示一、游戏界面二、得分情况&nb
- 泛型的简介1、为什么要使用泛型?一般使用在集合上,比如现在把一个字符串类型的值放入到集合里面,这个时候,这个值放到集合之后,失去本身的类型,
- SpringBoot Web依赖本文,主要记录如何切换Springboot内部 web依赖。在使用SpringBoot时,首先引人注意的便是
- 1.后台参数校验Spring Validation验证框架对参数的验证机制提供了@Validated(Spring JSR-303规范,是标
- 一、背景当我们在drools中编写规则时,有些时候存在重复的代码,那么我们是否可以将这些重复代码抽取出来,封装成一个function来调用呢
- 本文实例为大家分享了Java实现扑克牌程序的具体代码,供大家参考,具体内容如下思路:在实现之前,先要想好步骤,思路清晰才不会出错。要实现一副
- 前言aop面向切面编程,是编程中一个很重要的思想本篇文章主要介绍的是SpringBoot切面Aop的使用和案例什么是aopAOP(Aspec
- 使用ByteArrayOutputStream下载文件//文件名称String filepath = ServletActionContex
- 这篇文章主要介绍了新手学习微服务SpringCloud项目架构搭建方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学
- 查了网上的资料,有比较全面的,但有一个问题就是容易出现一个文字和框子不符合的现象。(仔细看,蓝色字母和背景的灰色有空白)要消除这个空白,很简
- 本文实例讲述了Java正则验证IP的方法。分享给大家供大家参考,具体如下:网上用正则验证IP的表达式有很多,一搜一大堆,可以自己写,但很麻烦
- 这篇文章主要介绍了通过实例解析JMM和Volatile底层原理,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,
- 在我们开发SpringBoot后端服务时,一般需要给前端统一响应格式,方便前端调试及配置错误提示等等。这篇文章讲讲实际工作中统一响应格式及统
- 本文实例为大家分享了Java简单实现定时器的具体代码,供大家参考,具体内容如下一、定时器定时器相当于一个任务管理器。有些任务可能现在执行,
- 本文实例讲述了C#实现在Form里面内嵌dos窗体的方法。分享给大家供大家参考。具体如下:using System;using System
- 1.应用实例需求: 演示 Spring-Boot 通过表单注册用户,并支持上传图片2.代码实现代码实现-文件上传创建 templates/u
- 参数为对象1、提交表单2、表单序列化,使用ajax提交var data = $("#addForm").serializ
- Interface Segregation Principle,ISP接口隔离原则主张使用多个专门的接口比使用单一的总接口要好。一个类对另外