Spring Boot + Logback 日志管理

本文参考:
http://www.jianshu.com/p/59787a123b05

在这里主要为实现Spring Boot中使用Logback,Logback相对来说是优秀于log4j的,支持多彩日志输出,日志切割,文件输出,自定义输出格式等特性。

实现步骤:

一、添加 pom.xml 依赖

        <!-- logback -->
        <dependency>
            <groupId>ch.qos.logback</groupId>
            <artifactId>logback-core</artifactId>
            <version>1.1.7</version>
        </dependency>
        <dependency>
            <groupId>ch.qos.logback</groupId>
            <artifactId>logback-classic</artifactId>
            <version>1.1.7</version>
            <exclusions>
                <exclusion>
                    <artifactId>slf4j-api</artifactId>
                    <groupId>org.slf4j</groupId>
                </exclusion>
            </exclusions>
        </dependency>

二、配置 application.yml

#根节点
logging:
  level: debug     #定义日志级别
  path: /data/logs/project/pay/              #指定日志输出路径
  config: classpath:logback.xml              #指定日志配置文件

三、编写Logback.xml配置文件

<?xml version="1.0" encoding="UTF-8"?>
<configuration>
    <include resource="org/springframework/boot/logging/logback/defaults.xml" />
    <property name="LOG_PATH" value="${LOG_PATH:-${LOG_TEMP:-${java.io.tmpdir:-/tmp}}}" />
    <!-- 项目日志输出级别 -->
    <logger name="org.springframework.web" level="DEBUG"/>

    <!-- 控制台输出 -->
    <appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
        <filter class="ch.qos.logback.classic.filter.ThresholdFilter">
            <level>TRACE</level> <!-- 日志过滤级别 -->
        </filter>
        <encoder>
            <!-- 如果编辑器不支持请用普通日志 CONSOLE_LOG_PATTERN-彩色日志 FILE_LOG_PATTERN-普通日志 -->
            <pattern>${CONSOLE_LOG_PATTERN}</pattern><!-- 格式化输出 -->
            <charset>utf8</charset> <!-- 输出编码 -->
        </encoder>
    </appender>

    <!-- 文件输出 -->
    <appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <filter class="ch.qos.logback.classic.filter.ThresholdFilter">
            <level>debug</level> <!-- 日志过滤级别 -->
        </filter>
        <encoder>
            <!-- 如果编辑器不支持请用普通日志 CONSOLE_LOG_PATTERN-彩色日志 FILE_LOG_PATTERN-普通日志 -->
            <pattern>${CONSOLE_LOG_PATTERN}</pattern><!-- 格式化输出 -->
            <charset>utf8</charset> <!-- 输出编码 -->
        </encoder>
        <file>${LOG_PATH}/info/info.log}</file><!-- 文件存放路径 -->
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <fileNamePattern>${LOG_PATH}/info/%d{yyyy-MM-dd}.log</fileNamePattern><!-- 每天归档 -->
            <maxHistory>7</maxHistory><!-- 日志存放周期(天) -->
        </rollingPolicy>
    </appender>
    <!-- 错误日志文件输出 -->
    <appender name="ERROR_FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <filter class="ch.qos.logback.classic.filter.ThresholdFilter">
            <level>ERROR</level> <!-- 日志过滤级别 -->
        </filter>
        <encoder>
            <!-- 如果编辑器不支持请用普通日志 CONSOLE_LOG_PATTERN-彩色日志 FILE_LOG_PATTERN-普通日志 -->
            <pattern>${CONSOLE_LOG_PATTERN}</pattern><!-- 格式化输出 -->
            <charset>utf8</charset> <!-- 输出编码 -->
        </encoder>
        <file>${LOG_PATH}/error/error.log}</file><!-- 文件存放路径 -->
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <fileNamePattern>${LOG_PATH}/error/%d{yyyy-MM-dd}.log</fileNamePattern><!-- 每天归档 -->
            <maxHistory>30</maxHistory><!-- 日志存放周期(天) -->
        </rollingPolicy>
    </appender>


    <root level="INFO">
        <appender-ref ref="CONSOLE" />
        <appender-ref ref="FILE" />
        <appender-ref ref="ERROR_FILE" />

    </root>
    
</configuration>

就这么简单,实现了Logback的集成。

有件事是肯定的,此生无论我们做了什么,我们都逃不开人生 -- 弗雷德里克·巴克曼 《一个叫欧维的男人决定去死》

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容