SpringBoot LogBack使用记录(未完待续) - Go语言中文社区

SpringBoot LogBack使用记录(未完待续)


一. slf4j log4j logback三者的关系

slf4j,The Simple Logging Facade for Java. 它是一系列的日志接口.

log4j和logback是日志接口的实现. 但是log4j遵循slf4j接口, logback遵循slf4j接口.而且logback拥有更好的性能. springboot默认使用logback作为日志框架.

二. springboot中使用logback

1. 引入依赖:

spring-boot-starter中默认集成了logback,和slf4j 因此我们不用额外引入依赖

<dependency>
     <groupId>org.springframework.boot</groupId>
     <artifactId>spring-boot-starter</artifactId>
</dependency>

另,当我们需要引入其他日志框架的时候,为了使用其他的日志框架,比如log4j时,需要在spring-boot-starter中排除掉logback.如:

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter</artifactId>
    <exclusions>
        <exclusion>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-logging</artifactId>
        </exclusion>
    </exclusions>
</dependency>

2. 引入配置

我的springboot项目结构如下图

我在application.yaml中加入如下参数指明了logback配置的位置

logging:
  config: classpath:cfg/logback-spring-${spring.profiles.active}.xml

logback配置简单示例:

<?xml version="1.0" encoding="UTF-8"?>
<configuration debug="false">
    <!--定义日志文件的存储地址 勿在 LogBack 的配置中使用相对路径-->
    <property name="LOG_HOME" value="${user.home}/cloud-sync/logs" />
    <!-- 控制台输出 -->
    <appender name="Console" class="ch.qos.logback.core.ConsoleAppender">
        <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
            <!--格式化输出:%d表示日期,%thread表示线程名,%-5level:级别从左显示5个字符宽度%msg:日志消息,%n是换行符-->
            <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS}-[%thread]-%-5level-%logger{50}: %msg%n</pattern>
        </encoder>
    </appender>
    <!-- 按天分割日志,并且限制每个日志大小 -->
    <appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
            <!-- rollover daily -->
            <fileNamePattern>${LOG_HOME}/consumer.%d{yyyy-MM-dd}.%i.log</fileNamePattern>
            <!-- each file should be at most 10MB, keep 3 days worth of history, but at most 1GB -->
            <maxFileSize>10MB</maxFileSize>
            <maxHistory>3</maxHistory>
            <totalSizeCap>1GB</totalSizeCap>
        </rollingPolicy>
        <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
            <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n</pattern>
        </encoder>
    </appender>
    <!--  专为 Redisson 定制 -->
    <logger name="org.redisson.api.RedissonClient"  level="TRACE" />

    <!-- 日志输出级别 -->
    <root level="INFO">
        <appender-ref ref="Console" />
        <appender-ref ref="FILE" />
    </root>
</configuration>

三. 配置详解

 

 

 

 

四. 参考文章

Spring boot——logback 基础使用篇(一)

Spring Boot中使用logback记录日志

看完这个不会配置 logback ,请你吃瓜!

 

 

 

 

版权声明:本文来源CSDN,感谢博主原创文章,遵循 CC 4.0 by-sa 版权协议,转载请附上原文出处链接和本声明。
原文链接:https://blog.csdn.net/dajiangqingzhou/article/details/92068694
站方申明:本站部分内容来自社区用户分享,若涉及侵权,请联系站方删除。
  • 发表于 2019-08-27 17:19:32
  • 阅读 ( 1687 )
  • 分类:

0 条评论

请先 登录 后评论

官方社群

GO教程

猜你喜欢