boot日志文件分等级并自动滚动拆分

这是一个关于日志配置的详细示例,涵盖了控制台和文件日志的格式、编码、滚动策略以及不同级别(ERROR, INFO)的日志过滤。配置中定义了彩色控制台日志和按日期及大小滚动的文件日志,确保了日志管理和存储的有效性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

<?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>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

lemon20120331

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值