Spring Boot 学习笔记之日志

版权声明:未经允许,请勿转载 https://blog.csdn.net/weixin_43723712/article/details/84204433

目前建议日志选择

slf4j+logback

日志门面:slf4j

日志实现:logback

slf4j如何实现日志门面?

如图所示,application通过slf4j API接口进行日志调用,slf4j 会调用相应实现类中的方法

在这里插入图片描述

项目如何实现统一日志记录?

日志适配图:依据该图进行Spring Boot日志框架的切换
在这里插入图片描述

Spring Boot 日志关系

Spring Boot默认使用了slf4j+logback组合进行日志管理,并且把其他的日志替换为了slf4j,进行统一的日志记录

Spring Boot 的日志的maven依赖

 <dependency>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-logging</artifactId>
      <version>2.1.0.RELEASE</version>
      <scope>compile</scope>
    </dependency>

底层依赖关系
在这里插入图片描述

引入其他框架时,为了让Spring Boot能适配所有的框架且底层使用slf4j+logback,需要排除框架本身的日志依赖

Spring Boot日志默认配置

1.默认日志级别为info

2.修改默认配置

//修改默认的日志级别
logging.level.com.zkq.springboot.study=debug
//指定指定日志输出到文件中文件的名称(一般不使用)
logging.file=
//指定日志输出到文件中文件的地址
logging.path=
//指定控制台日志输出格式
logging.pattern.console=
//指定文件中日志输出格式
logging.pattern.file=

3.如果自定义名为logback-spring.xml,由Spring Boot进行日志配置解析,可以使用Spring Boot的高级功能–多环境配置

多环境配置语句:

 <springProfile name="dev"></springProfile >

logback-spring.xml配置如下:

<?xml version="1.0" encoding="UTF-8" ?>
<configuration status="warn">
    <property name="LOG_PATTERN"
              value="%date{yyyy-MM-dd HH:mm:ss} |%-5level |%thread |%file:%line |%logger |%msg%n"/>
    <!-- appender是configuration的子节点,是负责写日志的组件。 -->
    <!-- 控制台打印日志配置 -->
    <appender name="console_log" class="ch.qos.logback.core.ConsoleAppender">
        <!--设置日志的输出格式-->
        <encoder>
            <pattern>${LOG_PATTERN}</pattern>
            <charset>utf-8</charset>
        </encoder>
    </appender>

    <springProfile name="!dev">
    <!-- 写入文件 INFO 日志配置 -->
    <!--级别排序为: TRACE < DEBUG < INFO < WARN < ERROR。-->
    <appender name="file_info_log" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <filter class="ch.qos.logback.classic.filter.LevelFilter">
            <level>INFO</level>
            <onMatch>ACCEPT</onMatch>
            <onMismatch>DENY</onMismatch>
        </filter>
        <encoder>
            <charset>UTF-8</charset>
            <pattern>${LOG_PATTERN}</pattern>
        </encoder>
        <!-- TimeBasedRollingPolicy: 最常用的滚动策略,它根据时间来制定滚动策略,既负责滚动也负责出发滚动 -->
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <!-- 活动文件的名字会根据fileNamePattern的值,每隔一段时间改变一次 -->
            <!-- 文件名:log/demo.2017-12-05.0.log -->
            <fileNamePattern>logs/info/info.%d.log</fileNamePattern>
            <!-- 每产生一个日志文件,该日志文件的保存期限为30天 -->
            <maxHistory>30</maxHistory>
        </rollingPolicy>
    </appender>

    <!-- 写入文件 ERROR 日志配置 -->
    <appender name="file_error_log" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <filter class="ch.qos.logback.classic.filter.LevelFilter">
            <level>ERROR</level>
            <onMatch>ACCEPT</onMatch>
            <onMismatch>DENY</onMismatch>
        </filter>
        <encoder>
            <charset>UTF-8</charset>
            <pattern>${LOG_PATTERN}</pattern>
        </encoder>
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <fileNamePattern>logs/error/error.%d.log</fileNamePattern>
            <maxHistory>30</maxHistory>
        </rollingPolicy>
    </appender>
    </springProfile>

    <!-- SQL相关日志输出-->
    <logger name="org.apache.ibatis" level="INFO" additivity="false" />
    <logger name="org.mybatis.spring" level="INFO" additivity="false" />
    <logger name="org.hibernate" level="info" additivity="false"></logger>
    <!--spring相关日志输出-->
    <logger name="org.springframework.boot" level="info" additivity="false"></logger>
    <logger name="org.springframework.beans" level="info" additivity="false"></logger>
    <logger name="org.springframework.core" level="info" additivity="false"></logger>
    <logger name="org.springframework.web" level="info" additivity="false"></logger>
    <logger name="org.springframework.jmx" level="info" additivity="false"></logger>
    <root level="DEBUG">
        <!--测试,开发使用配置-->
        <springProfile name="dev">
            <appender-ref ref="console_log"/>
        </springProfile>
        <!--项目上线使用配置-->
        <springProfile name="!dev">
         <appender-ref ref="file_info_log"/>
         <appender-ref ref="file_error_log"/>
        </springProfile>
    </root>

</configuration>

猜你喜欢

转载自blog.csdn.net/weixin_43723712/article/details/84204433