美文网首页
SpringBoot 日志记录

SpringBoot 日志记录

作者: 楚长铭 | 来源:发表于2020-05-22 14:48 被阅读0次
    • 使用数据库记录日志建议在aop中定义,或者自定义通用方法来记录,不建议写在xml文件中

    • logback-spring.xml文件放在resources文件夹下
    logging:
      config: classpath:logback-spring.xml
    

    <?xml version="1.0" encoding="UTF-8"?>
    <configuration scan="true" scanPeriod="10 seconds">
        <contextName>logback</contextName>
    
        <!-- 日志格式和颜色渲染 -->
    
        <!-- 彩色日志依赖的渲染类 -->
        <conversionRule conversionWord="clr" converterClass="org.springframework.boot.logging.logback.ColorConverter"/>
        <conversionRule conversionWord="wex"
                        converterClass="org.springframework.boot.logging.logback.WhitespaceThrowableProxyConverter"/>
        <conversionRule conversionWord="wEx"
                        converterClass="org.springframework.boot.logging.logback.ExtendedWhitespaceThrowableProxyConverter"/>
        <!-- 彩色日志格式 -->
        <property name="CONSOLE_LOG_PATTERN"
                  value="${CONSOLE_LOG_PATTERN:-%clr(%d{yyyy-MM-dd HH:mm:ss.SSS}){faint} %clr(${LOG_LEVEL_PATTERN:-%5p}) %clr(${PID:- }){magenta} %clr(---){faint} %clr([%15.15t]){faint} %clr(%-40.40logger{39}){cyan} %clr(:){faint} %m%n${LOG_EXCEPTION_CONVERSION_WORD:-%wEx}}"/>
    
        <!--输出到控制台-->
        <appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
            <!--此日志appender是为开发使用,只配置最底级别,控制台输出的日志级别是大于或等于此级别的日志信息-->
            <filter class="ch.qos.logback.classic.filter.ThresholdFilter">
                <!--日志输出级别-->
                <level>info</level>
            </filter>
            <encoder>
                <pattern>${CONSOLE_LOG_PATTERN}</pattern>
            </encoder>
        </appender>
    
    
        <!--日志输出位置-->
        <property name="log.path" value="/Users/ruanchenhao/WorkSpace/测试项目/logs"/>
        <property name="FILE_LOG_PATTERN" value="%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n"/>
    
        <!--输出到文档-->
        <appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
    
            <!--设置日志文件位置以及路径-->
            <file>${log.path}/test_demo.log</file>
    
            <!--日志输出格式-->
            <encoder>
                <pattern>${FILE_LOG_PATTERN}</pattern>
                <charset>UTF-8</charset> <!-- 设置字符集 -->
            </encoder>
    
            <!-- 日志记录器的滚动策略,按日期,按大小记录 -->
            <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
                <!-- 日志归档 -->
                <fileNamePattern>${log.path}/test_demo-%d{yyyy-MM-dd}.%i.log</fileNamePattern>
                <timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
                    <maxFileSize>100MB</maxFileSize>
                </timeBasedFileNamingAndTriggeringPolicy>
                <!--日志文档保留天数-->
                <maxHistory>15</maxHistory>
            </rollingPolicy>
    
            <!-- 日志级别 -->
            <filter class="ch.qos.logback.classic.filter.ThresholdFilter">
                <!--日志输出级别-->
                <level>info</level>
            </filter>
    
        </appender>
    
    
    
        <!-- 最终的策略 -->
        <springProfile name="dev">
            <root>
                <appender-ref ref="CONSOLE"/>
                <appender-ref ref="FILE"/>
            </root>
        </springProfile>
    
    
    </configuration>
    

    在xml中添加以下两个标签,可以读取yml文件中设置的值

     <springProperty name="logging.path" scope="context" source="logging.file.path"/>
      <springProperty name="logging.name" scope="context" source="spring.application.name"/>
    

    相关文章

      网友评论

          本文标题:SpringBoot 日志记录

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