美文网首页
springboot日志配置

springboot日志配置

作者: 冬月廿拾 | 来源:发表于2020-10-26 19:07 被阅读0次

    主要内容

    • 使用springboot默认的logback
    • 使用xml配置
    • 指定打印日志等级、分模块打印

    项目目录结构


    image.png

    在配置文件中指定logging的xml配置路径

    logging.config=classpath:logback-config.xml
    

    logback-config.xml基本配置

    <?xml version="1.0" encoding="UTF-8"?>
    <configuration debug="false" scan="false" scanPeriod="60 seconds">
        <property name="LOG_HOME" value="./logs/logback"/>
        <property name="appName" value="lzy-logDemo"/>
    
        <!-- 定义控制台输出 -->
        <appender name="stdout" class="ch.qos.logback.core.ConsoleAppender">
            <layout class="ch.qos.logback.classic.PatternLayout">
                <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} - [%thread] - %-5level - %logger{50} - %msg%n</pattern>
            </layout>
        </appender>
    
        <appender name="appLogAppender" class="ch.qos.logback.core.rolling.RollingFileAppender">
            <!-- 指定日志文件的名称 -->
    <!--        <file>${LOG_HOME}/${appName}.log</file>-->
    
            <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
                <!--文件路径,定义了日志的切分方式——把每一天的日志归档到一个文件中,以防止日志填满整个磁盘空间-->
                <fileNamePattern>${LOG_HOME}/${appName}-%d{yyyy-MM-dd}-%i.log</fileNamePattern>
                <!--只保留最近30天的日志-->
                <MaxHistory>30</MaxHistory>
                <timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
                    <!--用来指定日志文件的上限大小,那么到了这个值,就会删除旧的日志-->
                    <MaxFileSize>10MB</MaxFileSize>
                </timeBasedFileNamingAndTriggeringPolicy>
            </rollingPolicy>
    
            <layout class="ch.qos.logback.classic.PatternLayout">
                <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [ %thread ] - [%-5level] [ %logger{50} : %line ] - %msg%n</pattern>
            </layout>
            <!--日志输出编码格式化-->
            <encoder>
                <charset>UTF-8</charset>
                <pattern>%d [%thread] %-5level %logger{36} %line - %msg%n</pattern>
            </encoder>
        </appender>
    
        <root level="INFO">
            <appender-ref ref="appLogAppender"/>
        </root>
    </configuration>
    

    一些特殊需要处理

    1、指定模块日志输出的等级

    上面xml中的<root level="INFO"> <appender-ref ref="appLogAppender"/> </root>指定的是全局的日志 只打印INFO及以上级别的,如果某个模块/包/类 需要debug级别的日志就需要单独处理

    • 以数据读取的包 dal为例,它会打印执行的sql相关记录,默认日志级别为debug

    • <logger name="com.springbootdata.demo.dal" level="debug" additivity="false"> <appender-ref ref="dalLog" /> </logger> level指定日志级别,additivity是否上传到上一级“root”,appender-ref指定处理的appender

    • appender日志输出配置

    <appender name="dalLog" class="ch.qos.logback.core.rolling.RollingFileAppender">
            <!--如果只是想要 Error 级别的日志,那么需要过滤一下,默认是 info 级别的,ThresholdFilter-->
    <!--        <filter class="ch.qos.logback.classic.filter.ThresholdFilter">-->
    <!--            <level>Error</level>-->
    <!--        </filter>-->
            <!--日志名称,如果没有File 属性,那么只会使用FileNamePattern的文件路径规则
                如果同时有<File>和<FileNamePattern>,那么当天日志是<File>,明天会自动把今天
                的日志改名为今天的日期。即,<File> 的日志都是当天的。
            -->
    <!--        <File>${logback.logdir}/dal.${logback.appname}.log</File>-->
            <!--滚动策略,按照时间滚动 TimeBasedRollingPolicy-->
            <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
                <!--文件路径,定义了日志的切分方式——把每一天的日志归档到一个文件中,以防止日志填满整个磁盘空间-->
                <FileNamePattern>${LOG_HOME}/%d{yyyyMMdd}/dal.log</FileNamePattern>
                <!--只保留最近30天的日志-->
                <maxHistory>30</maxHistory>
                <!--用来指定日志文件的上限大小,那么到了这个值,就会删除旧的日志-->
                <totalSizeCap>12KB</totalSizeCap>
            </rollingPolicy>
            <!--日志输出编码格式化-->
            <encoder>
                <charset>UTF-8</charset>
                <pattern>%d [%thread] %-5level %logger{36} %line - %msg%n</pattern>
            </encoder>
        </appender>
    

    2、日志归档

    每天的日志放一个文件夹

    <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
                <!--文件路径,定义了日志的切分方式——把每一天的日志归档到一个文件中,以防止日志填满整个磁盘空间-->
        <FileNamePattern>${LOG_HOME}/%d{yyyyMMdd}/dal.log</FileNamePattern>
                <!--只保留最近30天的日志-->
                <maxHistory>30</maxHistory>
                <!--用来指定日志文件的上限大小,那么到了这个值,就会删除旧的日志-->
                <totalSizeCap>12KB</totalSizeCap>
    </rollingPolicy>
    

    3、error日志单独打印

    将error日志单独打印到一个文件,方便监控

    • 新建Error日志处理的appender
    <appender name="fileErrorLog" class="ch.qos.logback.core.rolling.RollingFileAppender">
            <!--如果只是想要 Error 级别的日志,那么需要过滤一下,默认是 info 级别的,ThresholdFilter-->
            <filter class="ch.qos.logback.classic.filter.ThresholdFilter">
                <level>Error</level>
            </filter>
            <!--日志名称,如果没有File 属性,那么只会使用FileNamePattern的文件路径规则
                如果同时有<File>和<FileNamePattern>,那么当天日志是<File>,明天会自动把今天
                的日志改名为今天的日期。即,<File> 的日志都是当天的。
            -->
    <!--        <File>${LOG_HOME}/%d{yyyyMMdd}/error.log</File>-->
            <!--滚动策略,按照时间滚动 TimeBasedRollingPolicy-->
            <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
                <!--文件路径,定义了日志的切分方式——把每一天的日志归档到一个文件中,以防止日志填满整个磁盘空间-->
                <FileNamePattern>${LOG_HOME}/%d{yyyyMMdd}/error.log</FileNamePattern>
                <!--只保留最近90天的日志-->
                <maxHistory>30</maxHistory>
                <!--用来指定日志文件的上限大小,那么到了这个值,就会删除旧的日志-->
                <totalSizeCap>1MB</totalSizeCap>
            </rollingPolicy>
            <!--日志输出编码格式化-->
            <encoder>
                <charset>UTF-8</charset>
                <pattern>%d [%thread] %-5level %logger{36} %line - %msg%n</pattern>
            </encoder>
        </appender>
    
    • root中指定
            <appender-ref ref="fileErrorLog"/>
    

    结果


    image.png

    整体xml配置

    <?xml version="1.0" encoding="UTF-8"?>
    <configuration debug="false" scan="false" scanPeriod="60 seconds">
        <property name="LOG_HOME" value="./logs/logback"/>
        <property name="appName" value="lzy-logDemo"/>
    
        <!-- 定义控制台输出 -->
        <appender name="stdout" class="ch.qos.logback.core.ConsoleAppender">
            <layout class="ch.qos.logback.classic.PatternLayout">
                <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} - [%thread] - %-5level - %logger{50} - %msg%n</pattern>
            </layout>
        </appender>
    
        <appender name="appLogAppender" class="ch.qos.logback.core.rolling.RollingFileAppender">
            <!-- 指定日志文件的名称 -->
    <!--        <file>${LOG_HOME}/${appName}.log</file>-->
    
            <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
                <!--文件路径,定义了日志的切分方式——把每一天的日志归档到一个文件中,以防止日志填满整个磁盘空间-->
                <fileNamePattern>${LOG_HOME}/%d{yyyyMMdd}/${appName}-%i.log</fileNamePattern>
                <!--只保留最近30天的日志-->
                <MaxHistory>30</MaxHistory>
                <timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
                    <!--用来指定日志文件的上限大小,那么到了这个值,就会删除旧的日志-->
                    <MaxFileSize>10MB</MaxFileSize>
                </timeBasedFileNamingAndTriggeringPolicy>
            </rollingPolicy>
    
            <layout class="ch.qos.logback.classic.PatternLayout">
                <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [ %thread ] - [%-5level] [ %logger{50} : %line ] - %msg%n</pattern>
            </layout>
            <!--日志输出编码格式化-->
            <encoder>
                <charset>UTF-8</charset>
                <pattern>%d [%thread] %-5level %logger{36} %line - %msg%n</pattern>
            </encoder>
        </appender>
    
        <!--error日志-->
        <appender name="fileErrorLog" class="ch.qos.logback.core.rolling.RollingFileAppender">
            <!--如果只是想要 Error 级别的日志,那么需要过滤一下,默认是 info 级别的,ThresholdFilter-->
            <filter class="ch.qos.logback.classic.filter.ThresholdFilter">
                <level>Error</level>
            </filter>
            <!--日志名称,如果没有File 属性,那么只会使用FileNamePattern的文件路径规则
                如果同时有<File>和<FileNamePattern>,那么当天日志是<File>,明天会自动把今天
                的日志改名为今天的日期。即,<File> 的日志都是当天的。
            -->
    <!--        <File>${LOG_HOME}/%d{yyyyMMdd}/error.log</File>-->
            <!--滚动策略,按照时间滚动 TimeBasedRollingPolicy-->
            <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
                <!--文件路径,定义了日志的切分方式——把每一天的日志归档到一个文件中,以防止日志填满整个磁盘空间-->
                <FileNamePattern>${LOG_HOME}/%d{yyyyMMdd}/error.log</FileNamePattern>
                <!--只保留最近90天的日志-->
                <maxHistory>30</maxHistory>
                <!--用来指定日志文件的上限大小,那么到了这个值,就会删除旧的日志-->
                <totalSizeCap>1MB</totalSizeCap>
            </rollingPolicy>
            <!--日志输出编码格式化-->
            <encoder>
                <charset>UTF-8</charset>
                <pattern>%d [%thread] %-5level %logger{36} %line - %msg%n</pattern>
            </encoder>
        </appender>
    
        <!--dal-->
        <appender name="dalLog" class="ch.qos.logback.core.rolling.RollingFileAppender">
            <!--如果只是想要 Error 级别的日志,那么需要过滤一下,默认是 info 级别的,ThresholdFilter-->
    <!--        <filter class="ch.qos.logback.classic.filter.ThresholdFilter">-->
    <!--            <level>Error</level>-->
    <!--        </filter>-->
            <!--日志名称,如果没有File 属性,那么只会使用FileNamePattern的文件路径规则
                如果同时有<File>和<FileNamePattern>,那么当天日志是<File>,明天会自动把今天
                的日志改名为今天的日期。即,<File> 的日志都是当天的。
            -->
    <!--        <File>${logback.logdir}/dal.${logback.appname}.log</File>-->
            <!--滚动策略,按照时间滚动 TimeBasedRollingPolicy-->
            <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
                <!--文件路径,定义了日志的切分方式——把每一天的日志归档到一个文件中,以防止日志填满整个磁盘空间-->
                <FileNamePattern>${LOG_HOME}/%d{yyyyMMdd}/dal.log</FileNamePattern>
                <!--只保留最近30天的日志-->
                <maxHistory>30</maxHistory>
                <!--用来指定日志文件的上限大小,那么到了这个值,就会删除旧的日志-->
                <totalSizeCap>12KB</totalSizeCap>
            </rollingPolicy>
            <!--日志输出编码格式化-->
            <encoder>
                <charset>UTF-8</charset>
                <pattern>%d [%thread] %-5level %logger{36} %line - %msg%n</pattern>
            </encoder>
        </appender>
    
        <!-- 日志输出级别 -->
        <logger name="org.springframework" level="debug"  additivity="false"/>
    <!--    <logger name="com.springbootdata.demo" level="debug"/>-->
        <logger name="com.springbootdata.demo.dal" level="debug" additivity="false">
            <appender-ref ref="dalLog" />
        </logger>
        <root level="INFO">
            <appender-ref ref="fileErrorLog"/>
            <appender-ref ref="stdout"/>
            <appender-ref ref="appLogAppender"/>
        </root>
    </configuration>
    

    相关文章

      网友评论

          本文标题:springboot日志配置

          本文链接:https://www.haomeiwen.com/subject/fnfzmktx.html