美文网首页
logback配置

logback配置

作者: Hello_DH | 来源:发表于2017-09-18 13:26 被阅读0次
    <?xml version="1.0" encoding="UTF-8"?>
    
    <!-- debug:打印logback内部日志信息,实时查看logback的运行状态,默认为false -->
    <!-- scan:配置文件如果发生改变,是否被重新加载,默认为true。 -->
    <!-- scanPeriod:设置检测配置文件是否有修改的时间间隔,如果没有给出时间单位,默认单位是毫秒,默认的时间间隔为1分钟,默认为true。 -->
    <configuration debug="true" scan="true" scanPeriod="30 seconds">
        <contextName>SpringBoot Demo</contextName>
        <!-- 时间戳定义,timeReference:使用日志产生日期为时间基准 -->
        <timestamp key="byDay" datePattern="yyyy-MM-dd" timeReference="contextBirth"/>
    
        <!--定义日志文件的存储地址 勿在 LogBack 的配置中使用相对路径,可以使用系统变量 -->
        <!-- <property name="LOG_HOME" value="${app.home}/log" /> -->
        <property name="LOG_HOME" value="log"/>
    
        <!-- appender很重要,一个配置文件会有多个appender -->
        <!-- ConsoleApperder意思是从console中打印出来 -->
        <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
            <!-- On Windows machines setting withJansi to true enables ANSI
             color code interpretation by the Jansi library. This requires
             org.fusesource.jansi:jansi:1.8 on the class path.  Note that
             Unix-based operating systems such as Linux and Mac OS X
             support ANSI color codes by default. 
             http://blog.csdn.net/u013613428/article/details/51499552
           -->
            <withJansi>true</withJansi>
            <!-- 过滤器,一个appender可以有多个 -->
            <!-- 阈值过滤,就是log行为级别过滤,debug及debug以上的信息会被打印出来 -->
            <filter class="ch.qos.logback.classic.filter.ThresholdFilter">
                <level>debug</level>
            </filter>
            <!-- encoders are assigned the type
                 ch.qos.logback.classic.encoder.PatternLayoutEncoder by default -->
            <!-- encoder编码规则 -->
            <encoder>
                <!--<pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</pattern>-->
                <!--<pattern>%d %contextName %msg%n</pattern>-->
                <!-- pattern模式 %d时间 %thread 线程名 %level行为级别 %logger logger名称 %method 方法名称 %message 调用方法的入参消息 -->
                <pattern>%-4d [%green(%thread)] %highlight(%-5level) %cyan(%logger).%-10method - %message%n</pattern>
            </encoder>
     <!-- 常用的Pattern变量,大家可打开该pattern进行输出观察 -->
            <!-- 
              <pattern>
                  %d{yyyy-MM-dd HH:mm:ss} [%level] - %msg%n
                  Logger: %logger
                  Class: %class
                  File: %file
                  Caller: %caller
                  Line: %line
                  Message: %m
                  Method: %M
                  Relative: %relative
                  Thread: %thread
                  Exception: %ex
                  xException: %xEx
                  nopException: %nopex
                  rException: %rEx
                  Marker: %marker
                  %n
                  
              </pattern>
               -->
        </appender>
    
        <!-- 按照每天生成日志文件 -->
        <appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
            <!-- 日志输出文件 -->
            <file>${LOG_HOME}/LoggingBack.log</file>
            <!-- 追加日志到原文件结尾 -->
            <append>true</append>
            <!-- timebasedrollingpolicy:演示时间和大小为基础的日志文件归档 -->
            <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
                <!-- 归档的日志文件的路径,例如今天是2013-12-21日志,当前写的日志文件路径为file节点指定。 -->
                <!--可以将此文件与file指定文件路径设置为不同路径,从而将当前日志文件或归档日志文件置不同的目录。 -->
                <!--而2013-12-21的日志文件在由fileNamePattern指定。%d{yyyy-MM-dd}指定日期格式,%i指定索引 -->
                <!-- 文件滚动日期格式:每天:.YYYY-MM-dd(默认);每星期:.YYYY-ww;每月:.YYYY-MM -->
                <!-- 每隔半天:.YYYY-MM-dd-a;每小时:.YYYY-MM-dd-HH;每分钟:.YYYY-MM-dd-HH-mm -->
                <fileNamePattern>${LOG_HOME}/log-%d{yyyy-MM-dd}.%i.log</fileNamePattern>
                <!-- 控制归档文件的最大数量的保存,删除旧的文件,默认单位天数 -->
                <maxHistory>7</maxHistory>
                <!-- 设置当前日志的文件的大小,决定日志翻滚 -->
                <timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
                    <!-- 除按日志记录之外,还配置了日志文件不能超过10M(默认),若超过10M,日志文件会以索引0开始, -->
                    <maxFileSize>10MB</maxFileSize>
                </timeBasedFileNamingAndTriggeringPolicy>
            </rollingPolicy>
    <!-- encoders 作用是将logger事件转换成字节数组,并将字节数组写入到输出流-->
    
            <encoder>
                <pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger - %msg%n
                </pattern>
            </encoder>
        </appender>
    
        <appender name="FILE-INFO" class="ch.qos.logback.core.rolling.RollingFileAppender">
            <!-- 这里添加一个过滤器 -->
            <file>${LOG_HOME}/LoggingBack-info.log</file>
            <filter class="ch.qos.logback.classic.filter.LevelFilter">
                <level>INFO</level>
                <onMatch>ACCEPT</onMatch>
                <onMismatch>DENY</onMismatch>
            </filter>
            <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
                <fileNamePattern>${LOG_HOME}/LOG-INFO-%d{yyyy-MM-dd}.%i.log</fileNamePattern>
                <maxHistory>7</maxHistory>
                <timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
                    <maxFileSize>10MB</maxFileSize>
                </timeBasedFileNamingAndTriggeringPolicy>
            </rollingPolicy>
            <encoder>
                <pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger - %msg%n
                </pattern>
            </encoder>
        </appender>
    
        <appender name="FILE-ERROR" class="ch.qos.logback.core.rolling.RollingFileAppender">
            <!-- 这里添加一个过滤器 -->
            <file>${LOG_HOME}/LoggingBack-error.log</file>
            <!--<filter>标签。
            过滤器,执行一个过滤器会有返回个枚举值,即DENY,NEUTRAL,ACCEPT其中之一。
            返回DENY,日志将立即被抛弃不再经过其他过滤器;
            返回NEUTRAL,有序列表里的下个过滤器过接着处理日志;
            返回ACCEPT,日志会被立即处理,不再经过剩余过滤器。
            过滤器被添加到<Appender> 中,为<Appender> 添加一个或多个过滤器后,可以用任意条件对日志进行过滤。<Appender> 有多个过滤器时,按照配置顺序执行。
           -->
            <filter class="ch.qos.logback.classic.filter.LevelFilter">
                <level>ERROR</level>
                <onMatch>ACCEPT</onMatch>
                <onMismatch>DENY</onMismatch>
            </filter>
            <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
                <fileNamePattern>${LOG_HOME}/LOG-ERROR-%d{yyyy-MM-dd}.%i.log</fileNamePattern>
                <maxHistory>7</maxHistory>
                <timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
                    <maxFileSize>10MB</maxFileSize>
                </timeBasedFileNamingAndTriggeringPolicy>
            </rollingPolicy>
            <encoder>
                <pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger - %msg%n
                </pattern>
            </encoder>
        </appender>
    
        <!-- 可以写多个日志文件appender,然后区分多个模块的日志 -->
        <appender name="BACKUP" class="ch.qos.logback.core.rolling.RollingFileAppender">
            <file>${LOG_HOME}/LoggingBack2.log</file>
            <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
                <fileNamePattern>${LOG_HOME}/LOG-%d{yyyy-MM-dd}.%i.log</fileNamePattern>
                <maxHistory>7</maxHistory>
                <timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
                    <maxFileSize>10MB</maxFileSize>
                </timeBasedFileNamingAndTriggeringPolicy>
            </rollingPolicy>
            <encoder>
                <pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger - %msg%n
                </pattern>
            </encoder>
        </appender>
    
        <!-- 为单独的包配置日志级别,若root的级别大于此级别, 此处级别也会输出
           应用场景:生产环境一般不会将日志级别设置为trace或debug,但是为详细的记录SQL语句的情况,
           可将hibernate的级别设置为debug,如此一来,日志文件中就会出现hibernate的debug级别日志,
           而其它包则会按root的级别输出日志
       -->
        <logger name="org.hibernate.SQL" level="DEBUG"/>
        <logger name="org.hibernate.jdbc" level="DEBUG"/>
        <logger name="org.springframework" level="DEBUG"/>
    
        <!-- 指定一个包,name必填,additivity选填:控制是否继承父类appender,默认true -->
        <!-- level选填,如果木有指定从最近的父类继承,顶级为root的级别 -->
        <logger name="com.wisely.ch7_7" additivity="true">
            <appender-ref ref="FILE"/>
            <appender-ref ref="FILE-INFO"/>
            <appender-ref ref="FILE-ERROR"/>
            <appender-ref ref="BACKUP"/>
        </logger>
        <!-- root, 只有在level及以上级别的日志会被输出 -->
        <!-- 例如: 当root level设置为INFO时, appender DEBUG中无法获取到DEBUG级别的日志事件, 则DEBUG日志信息也不会写入debug.log中. -->
        <root level="DEBUG">
            <appender-ref ref="STDOUT"/>
        </root>
    </configuration>  
    

    相关文章

      网友评论

          本文标题:logback配置

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