Spring Boot 日志文件

Siona

Spring Boot 日志文件

1. logback-spring.xml

放到任一 module 中的 resources 目录下,SpringBoot 会自动识别。

<?xml version="1.0" encoding="UTF-8"?>
<configuration scan="true">

    <!-- 日志输出上下文名称 -->
    <contextName>siona-service</contextName>
    <!-- 输出日志到控制台 ConsoleAppender -->
    <appender name="ConsoleAppender" class="ch.qos.logback.core.ConsoleAppender">
        <withJansi>true</withJansi>
        <encoder>
            <!--<pattern>%d %p (%file:%line\)- %m%n</pattern>-->
            <!--格式化输出:%d:表示日期   %thread:表示线程名   %-5level: 级别从左显示 5 个字符宽度  %msg:日志消息  %n:是换行符-->
            <pattern>1-%d{yyyy-MM-dd HH:mm:ss} [%thread] %highlight(%-5level) %boldGreen(%logger) - %highlight(%msg%n)
            </pattern>
            <charset>UTF-8</charset>
        </encoder>
    </appender>

    <!-- 输出日志到文件  每天一个文件 -->
    <!--输出每天的运行日志到文件 SystemOut.log-->
    <appender name="SystemOutFileAppender" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <!-- 正在记录的日志文件的路径及文件名 -->
        <file>logs/info.log</file>
        <!-- 日志记录器的滚动策略,按日期,按大小记录 -->
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <!-- 归档的日志文件的路径。%d{yyyy-MM-dd} 指定日期格式,%i 指定索引 -->
            <fileNamePattern>logs/info-%d{yyyy-MM-dd}.%i.log</fileNamePattern>
            <!--设置日志文件的保留天数 (maxHistory), 比如设置为 15 天-->
            <maxHistory>5</maxHistory>
            <!-- 除按日志记录之外,还配置了日志文件不能超过 2M,若超过 2M,日志文件会以索引 0 开始 -->
            <timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
                <maxFileSize>2MB</maxFileSize>
            </timeBasedFileNamingAndTriggeringPolicy>
        </rollingPolicy>
        <!-- 追加方式记录日志 -->
        <append>true</append>
        <!-- 日志文件的格式 -->
        <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
            <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger Line:%-3L - %msg%n</pattern>
            <charset>utf-8</charset>
        </encoder>
        <!-- 此日志文件记录 debug 及以上级别的 -->
        <filter class="ch.qos.logback.classic.filter.LevelFilter">
            <level>info</level>
            <onMatch>ACCEPT</onMatch>
            <onMismatch>DENY</onMismatch>
        </filter>
    </appender>

    <!-- 输出日志到文件  每天一个文件 -->
    <!--输出每天的运行日志到文件 SystemErrOut.log-->
    <appender name="ErrOutFileAppender" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <!-- 正在记录的日志文件的路径及文件名 -->
        <file>logs/error.log</file>
        <!-- 日志记录器的滚动策略,按日期,按大小记录 -->
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <!-- 归档的日志文件的路径。%d{yyyy-MM-dd} 指定日期格式,%i 指定索引 -->
            <fileNamePattern>logs/error-%d{yyyy-MM-dd}.%i.log</fileNamePattern>
            <!--设置日志文件的保留天数 (maxHistory), 比如设置为 30 天-->
            <maxHistory>5</maxHistory>
            <!-- 除按日志记录之外,还配置了日志文件不能超过 2M,若超过 2M,日志文件会以索引 0 开始 -->
            <timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
                <maxFileSize>2MB</maxFileSize>
            </timeBasedFileNamingAndTriggeringPolicy>
        </rollingPolicy>
        <!-- 追加方式记录日志 -->
        <append>true</append>
        <!-- 日志文件的格式 -->
        <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
            <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger Line:%-3L - %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>

    <!-- 输出日志到文件  文件大小到达指定尺寸的时候文件会自动回滚 -->
    <!-- 输出运行的 SQL 语句日志到文件 SqlOut.log -->
    <appender name="SqlOutFileAppender" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <!-- 正在记录的日志文件的路径及文件名 -->
        <file>logs/db.log</file>
        <!-- 日志记录器的滚动策略,按日期,按大小记录 -->
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <!-- 归档的日志文件的路径。%d{yyyy-MM-dd} 指定日期格式,%i 指定索引 -->
            <fileNamePattern>logs/db-%d{yyyy-MM-dd}.%i.log</fileNamePattern>
            <!--设置日志文件的保留天数 (maxHistory), 比如设置为 30 天-->
            <maxHistory>5</maxHistory>
            <!-- 除按日志记录之外,还配置了日志文件不能超过 2M,若超过 2M,日志文件会以索引 0 开始 -->
            <timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
                <maxFileSize>2MB</maxFileSize>
            </timeBasedFileNamingAndTriggeringPolicy>
        </rollingPolicy>
        <!-- 追加方式记录日志 -->
        <append>true</append>
        <!-- 日志文件的格式 -->
        <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
            <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger Line:%-3L - %msg%n</pattern>
            <charset>utf-8</charset>
        </encoder>
        <!-- 此日志文件记录sql trace -->
        <filter class="ch.qos.logback.classic.filter.LevelFilter">
            <level>debug</level>
            <onMatch>ACCEPT</onMatch>
            <onMismatch>DENY</onMismatch>
        </filter>
    </appender>


    <!--这个 logger 的设置是:举例在 org.springframework 包下面的所有输出日志必须级别 level 在 info 及以上级别才会被输出!-->
    <!--这样可以避免输出一些 spring 框架的许多常见 debug 信息!-->
    <root level="ERROR">
        <appender-ref ref="ErrOutFileAppender"/>
        <appender-ref ref="SystemOutFileAppender"/>
        <appender-ref ref="ConsoleAppender"/>
    </root>
    <logger name="org.mybatis" level="ERROR"/>
    <logger name="org.springframework" level="ERROR"/>
    <logger name="org.json" level="ERROR"/>
    <logger name="io.netty" level="ERROR"/>
    <logger name="org.slf4j" level="ERROR"/>
    <logger name="ch.qos.logback" level="ERROR"/>

</configuration>

2. application.yml 配置文件

application-dev.yml

logging:
  level:
    org.springframework: ERROR
    org.mybatis: DEBUG
    com.qx: DEBUG

application-prod.yml

logging:
  level:
    org.springframework: ERROR
    org.mybatis: INFO
    com.qx: INFO
Last Updated 3/2/2024, 4:00:59 PM