<?xml version="1.0" encoding="utf-8" ?>
<configuration>
<contextName>nhg</contextName>
<!-- 日志输出目录 根据自己实际情况改 -->
<property name="log.path" value="logs"/>
<!-- 控制台日志格式:彩色日志 -->
<!-- magenta:洋红 -->
<!-- boldMagenta:粗红 -->
<!-- cyan:青色 -->
<!-- white:白色 -->
<!-- magenta:洋红 -->
<property name="CONSOLE_LOG_PATTERN"
value="%yellow(%date{yyyy-MM-dd HH:mm:ss}) %highlight([%-5level]) %green(%logger) %msg%n"/>
<!-- 文件日志格式 -->
<property name="FILE_LOG_PATTERN"
value="%date{yyyy-MM-dd HH:mm:ss} [%-5level] %thread %file:%line %logger %msg%n"/>
<!-- 编码 -->
<property name="ENCODING"
value="UTF-8"/>
<!-- appender 负责写日志组件 -->
<!-- 控制台日志 -->
<appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
<encoder>
<pattern>${CONSOLE_LOG_PATTERN}</pattern>
<charset>${ENCODING}</charset>
</encoder>
</appender>
<!--输出错误日志-->
<appender name="ERROR" class="ch.qos.logback.core.rolling.RollingFileAppender">
<!-- 日志名称的格式 -->
<encoder>
<pattern>${FILE_LOG_PATTERN}</pattern>
<charset>${ENCODING}</charset>
</encoder>
<append>true</append>
<file>logs/error.log</file>
<!-- 配置滚动的策略 -->
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<!-- 日志归档路径以及格式 -->
<fileNamePattern>${log.path}/error/log-rolling-%d{yyyy-MM-dd}.%i.log</fileNamePattern>
<!-- 归档日志文件保留最大数量 -->
<maxHistory>15</maxHistory>
<!-- 设置触发滚动的时机 -->
<timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
<!-- 日志文件最大内存 -->
<maxFileSize>512000KB</maxFileSize>
</timeBasedFileNamingAndTriggeringPolicy>
</rollingPolicy>
<filter class="ch.qos.logback.classic.filter.LevelFilter">
<level>ERROR</level>
<onMatch>ACCEPT</onMatch>
<onMismatch>DENY</onMismatch>
</filter>
</appender>
<appender name="INFO" class="ch.qos.logback.core.rolling.RollingFileAppender">
<encoder>
<pattern>${FILE_LOG_PATTERN}</pattern>
<charset>${ENCODING}</charset>
</encoder>
<append>true</append>
<file>logs/info.log</file>
<!-- 设置滚动日志记录的滚动策略 -->
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<!-- 日志归档路径以及格式 -->
<fileNamePattern>${log.path}/info/log-rolling-%d{yyyy-MM-dd}.%i.log</fileNamePattern>
<!-- 归档日志文件保留最大数量 -->
<maxHistory>15</maxHistory>
<!-- 设置触发滚动的时机 -->
<timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
<!-- 日志文件最大内存 -->
<!-- <maxFileSize>512000KB</maxFileSize>-->
<maxFileSize>10KB</maxFileSize>
</timeBasedFileNamingAndTriggeringPolicy>
</rollingPolicy>
<filter class="ch.qos.logback.classic.filter.LevelFilter">
<!--可以修改成INFO,DEBUG等-->
<level>INFO</level>
<onMatch>ACCEPT</onMatch>
<onMismatch>DENY</onMismatch>
</filter>
</appender>
<!-- 日志记录器 根据自己实际情况改 -->
<logger name="com.zhm" level="INFO">
<appender-ref ref="CONSOLE"/>
<!-- <appender-ref ref="FILE"/>-->
<appender-ref ref="INFO"/>
<appender-ref ref="ERROR"/>
</logger>
<!-- 多环境节点 根据自己实际情况改 -->
<!-- 开发环境和测试环境 -->
<springProfile name="dev,test">
<logger name="com.zhm" level="INFO">
<appender-ref ref="CONSOLE"/>
<appender-ref ref="INFO"/>
<appender-ref ref="ERROR"/>
</logger>
</springProfile>
<!-- 生产环境 根据自己实际情况改-->
<springProfile name="prod">
<logger name="com.zhm" level="ERROR">
<appender-ref ref="CONSOLE"/>
<appender-ref ref="INFO"/>
<appender-ref ref="ERROR"/>
</logger>
</springProfile>
</configuration>
boot日志文件分等级并自动滚动拆分
最新推荐文章于 2025-07-22 22:38:18 发布
这是一个关于日志配置的详细示例,涵盖了控制台和文件日志的格式、编码、滚动策略以及不同级别(ERROR, INFO)的日志过滤。配置中定义了彩色控制台日志和按日期及大小滚动的文件日志,确保了日志管理和存储的有效性。
2590

被折叠的 条评论
为什么被折叠?



