Springboot按天生成日志文件
原文链接:https://blog.csdn.net/weixin_47798667/article/details/131846942
1:首先再yml文件上加上配置
-
logging:
-
config: classpath:logback-spring.xml
2:新建一个logback-spring.xml文件
文件内容是如下
-
<?xml version="1.0" encoding="UTF-8"?>
-
<configuration>
-
<property name="LOG_CONTEXT_NAME" value="log"/>
-
<!--定义日志文件的存储地址 勿在 LogBack 的配置中使用相对路径-->
-
<property name="LOG_HOME" value="logs/${LOG_CONTEXT_NAME}" />
-
<!-- 定义日志上下文的名称 -->
-
<contextName>${LOG_CONTEXT_NAME}</contextName>
-
<!-- 控制台输出 -->
-
<!--<appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
-
<encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
-
<!–格式化输出:%d表示日期,%thread表示线程名,%-5level:级别从左显示5个字符宽度%msg:日志消息,%n是换行符–>
-
<pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %highlight(%-5level) %cyan(%logger{50}:%L) - %msg%n</pattern>
-
<charset>utf-8</charset>
-
</encoder>
-
<filter class="ch.qos.logback.classic.filter.ThresholdFilter">
-
<level>INFO</level>
-
</filter>
-
</appender>-->
-
-
-
<!-- 彩色日志依赖的渲染类 -->
-
<conversionRule conversionWord="clr" converterClass="org.springframework.boot.logging.logback.ColorConverter" />
-
<conversionRule conversionWord="wex" converterClass="org.springframework.boot.logging.logback.WhitespaceThrowableProxyConverter" />
-
<conversionRule conversionWord="wEx" converterClass="org.springframework.boot.logging.logback.ExtendedWhitespaceThrowableProxyConverter" />
-
<!-- 彩色日志格式 -->
-
<property name="CONSOLE_LOG_PATTERN" value="${CONSOLE_LOG_PATTERN:-%clr(%d{yyyy-MM-dd HH:mm:ss.SSS}){faint} %clr(${LOG_LEVEL_PATTERN:-%5p}) %clr(${PID:- }){magenta} %clr(---){faint} %clr([%15.15t]){faint} %clr(%-40.40logger{39}){cyan} %clr(:){faint} %m%n${LOG_EXCEPTION_CONVERSION_WORD:-%wEx}}"/>
-
-
<!--1. 输出到控制台-->
-
<appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
-
<!--此日志appender是为开发使用,只配置最底级别,控制台输出的日志级别是大于或等于此级别的日志信息-->
-
<filter class="ch.qos.logback.classic.filter.ThresholdFilter">
-
<level>INFO</level>
-
</filter>
-
<encoder>
-
<Pattern>${CONSOLE_LOG_PATTERN}</Pattern>
-
<!-- 设置字符集 -->
-
<charset>UTF-8</charset>
-
</encoder>
-
</appender>
-
-
<!--info日志统一输出到这里-->
-
<appender name="file.info" class="ch.qos.logback.core.rolling.RollingFileAppender">
-
<Prudent>true</Prudent>
-
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
-
<!--日志文件输出的文件名,按小时生成-->
-
<FileNamePattern>${LOG_HOME}/%d{yyyy-MM-dd}/info/info.%d{yyyy-MM-dd-HH}.%i.log</FileNamePattern>
-
<!--日志文件保留天数-->
-
<MaxHistory>30</MaxHistory>
-
<timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
-
<!-- 除按日志记录之外,还配置了日志文件不能超过10M(默认),若超过10M,日志文件会以索引0开始, -->
-
<maxFileSize>10MB</maxFileSize>
-
</timeBasedFileNamingAndTriggeringPolicy>
-
</rollingPolicy>
-
<encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
-
<!--格式化输出:%d表示日期,%thread表示线程名,%-5level:级别从左显示5个字符宽度 %method 方法名 %L 行数 %msg:日志消息,%n是换行符-->
-
<pattern> %d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{56}.%method:%L - %msg%n</pattern>
-
<charset>utf-8</charset>
-
</encoder>
-
<!-- 此日志文件只记录info级别的 -->
-
<filter class="ch.qos.logback.classic.filter.LevelFilter">
-
<level>INFO</level>
-
<onMatch>ACCEPT</onMatch>
-
<onMismatch>DENY</onMismatch>
-
</filter>
-
</appender>
-
-
-
<!--错误日志统一输出到这里-->
-
<appender name="file.error" class="ch.qos.logback.core.rolling.RollingFileAppender">
-
<Prudent>true</Prudent>
-
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
-
<!--日志文件输出的文件名,按天生成-->
-
<FileNamePattern>${LOG_HOME}/%d{yyyy-MM-dd}/error/error.%d{yyyy-MM-dd}.%i.log</FileNamePattern>
-
<!--日志文件保留天数-->
-
<MaxHistory>30</MaxHistory>
-
<timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
-
<!-- 除按日志记录之外,还配置了日志文件不能超过10M(默认),若超过10M,日志文件会以索引0开始, -->
-
<maxFileSize>10MB</maxFileSize>
-
</timeBasedFileNamingAndTriggeringPolicy>
-
</rollingPolicy>
-
<encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
-
<!--格式化输出:%d表示日期,%thread表示线程名,%-5level:级别从左显示5个字符宽度 %method 方法名 %L 行数 %msg:日志消息,%n是换行符-->
-
<pattern> %d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{56}.%method:%L - %msg%n</pattern>
-
<charset>utf-8</charset>
-
</encoder>
-
<!-- 此日志文件只记录error级别的 -->
-
<filter class="ch.qos.logback.classic.filter.LevelFilter">
-
<level>ERROR</level>
-
<onMatch>ACCEPT</onMatch>
-
<onMismatch>DENY</onMismatch>
-
</filter>
-
</appender>
-
-
<!--warn日志统一输出到这里-->
-
<appender name="file.warn" class="ch.qos.logback.core.rolling.RollingFileAppender">
-
<Prudent>true</Prudent>
-
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
-
<FileNamePattern>${LOG_HOME}/%d{yyyy-MM-dd}/warn/warn.%d{yyyy-MM-dd}.%i.log</FileNamePattern>
-
<!--日志文件保留天数-->
-
<MaxHistory>30</MaxHistory>
-
<timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
-
<!-- 除按日志记录之外,还配置了日志文件不能超过10M(默认),若超过10M,日志文件会以索引0开始, -->
-
<maxFileSize>10MB</maxFileSize>
-
</timeBasedFileNamingAndTriggeringPolicy>
-
</rollingPolicy>
-
<encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
-
<!--格式化输出:%d表示日期,%thread表示线程名,%-5level:级别从左显示5个字符宽度 %method 方法名 %L 行数 %msg:日志消息,%n是换行符-->
-
<pattern> %d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{56}.%method:%L - %msg%n</pattern>
-
<charset>utf-8</charset>
-
</encoder>
-
<!-- 此日志文件只记录warn级别的 -->
-
<filter class="ch.qos.logback.classic.filter.LevelFilter">
-
<level>WARN</level>
-
<onMatch>ACCEPT</onMatch>
-
<onMismatch>DENY</onMismatch>
-
</filter>
-
</appender>
-
-
-
-
<!-- 日志输出级别 -->
-
<root level="DEBUG">
-
<appender-ref ref="STDOUT" />
-
<appender-ref ref="file.error" />
-
<appender-ref ref="file.info" />
-
<appender-ref ref="file.warn" />
-
</root>
-
-
</configuration>
3:生成的日志文件如下
4:测试info 和error
此时日志文件会保存错误打印的日志了