记录springboot
项目配置logback
日志文件管理:
SpringBoot
项目配置logback
理论上需要添加logback-classic
依赖jar
包:
ch.qos.logback logback-classic 1.2.3
但是因为SpringBoot
项目默认就是使用的就是logback
日志系统,创建SpringBoot
项目时引入的spring-boot-starter
或者spring-boot-starter-web
依赖jar
包中已经包含了spring-boot-starter-logging
的依赖,里面同时包含多种日志系统依赖,如下图所示:
包括logback和log4j,所以,无需额外添加依赖,直接配置logback.xml
就可以了。
此外,如果需要切换为log4j2
,那么需要在spring-boot-starter-web
依赖中排除springboot
自带的commons‐logging
,然后在引入log4j2
的依赖jar
包,如下所示:
org.springframework.boot spring-boot-starter-web commons‐logging commons‐logging org.springframework.boot spring-boot-starter-log4j2
前面说到SpringBoot
项目默认使用logback
,那么对于logback
的配置情况,SpringBoot
又是如何定义的呢?
首先,SpringBoot
会从resource
包下查找logback-test.xml
或logback.xml
,如果这两个都不存在,则会调用BasicConfigurator
,创建一个最小化的基本配置。
最小化配置由一个关联到根logger
的ConsoleAppender
组成,默认输出模式为%d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n
,root logger
级别为DEBUG
,所以并不会生成日志文件,只会输出到控制台。
通过自定义logback.xml
配置文件来控制日志输出情况,通常我们会配置三个日志组件:
以下为logback.xml
完整配置
%d{yyyy-MM-dd HH:mm:ss.SSS} %-5level ${PID:-} --- [%t] %logger{50} - %msg%n ${LOG_PATH}/info.log ${LOG_PATH}/info-%d{yyyy-MM-dd}.%i.log 30 100MB %d{yyyy-MM-dd HH:mm:ss.SSS} %-5level ${PID:-} --- [%t] %logger{50} - %msg%n ERROR ${LOG_PATH}/error.log ${LOG_PATH}/error-%d{yyyy-MM-dd}.%i.log 30 100MB %d{yyyy-MM-dd HH:mm:ss.SSS} %-5level ${PID:-} --- [%t] %logger{50} - %msg%n
configuration包含以下三个属性:
用来定义变量值,包含以下两个属性
通过property
定义的值会被插入到logger
上下文中,可以使${}
来使用变量,这里定义了log
的保存位置根目录。
是负责写日志的组件,通过自定义日志组件控制日志输出的情况,包含以下两个属性:
不同的class,对应不同的功能:
如ch.qos.logback.core.ConsoleAppender
会把日志输出到控制台
ch.qos.logback.core.rolling.RollingFileAppender
把日志内容输出到指定文件
File节点:日志文件输出的文件名
${LOG_PATH}/info.log
filter节点:过滤器,用来指定日志组件的日志输出级别,优先级高于root节点的level。
ERROR
滚动日志文件配置,涉及日志文件的移动和重命名,只有一个class
属性,用来指定滚动策略,这里使用的是ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy
包含以下三个属性:
${LOG_PATH}/error-%d{yyyy-MM-dd}.%i.log 30 100MB
%d{yyyy-MM-dd HH:mm:ss.SSS} %-5level ${PID:-} --- [%t] %logger{50} - %msg%n
对记录事件进行格式化,负责两件事,一是把日志信息转换成字节数组,二是把字节数组写入到输出流。
PatternLayoutEncoder 是唯一有用的且默认的encoder ,有一个
根loger
,是所有loger
的最上级,且只有一个level
节点,用类设置打印日志的级别,默认值为debug
,通常设置为info
,此外还有trace、warn、error、all、off
级别。
子节点appender-ref的ref
属性指定日志组件名称,即appender
的name
属性值。
在yml
文件中增加logging.config
指定配置文件地址,命名为logback时可以不需要配置,
SpringBoot`会自动查找。
level
设置指定路径下的日志输出级别。
logging: config: classpath:logback.xml level: com: springboot: debug
如图所示,项目启动后,访问接口输出日志内容并生成指定日志文件:
内容参考
博客园-ryelqy-logback的使用和logback.xml详解
到此这篇关于springboot项目配置logback日志系统的实现的文章就介绍到这了,更多相关springboot配置logback日志系统内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!