spring-boot-route(十六)使用logback生产日志文件

日志是一个系统很是重要的一部分,咱们常常须要经过查看日志来定位问题,今天咱们一块儿来学习一下Spring Boot的日志系统。有不少同窗习惯性的在生产代码中使用System.out来输出日志,这是不推荐的一种作法,由于System.out是一个同步操做,会在必定程度上影响系统性能,而Logger是一个异步操做。html

Spring Boot默认的日志系统是logback,固然咱们并不须要去引用logback的依赖,由于在spring-boot-starter中已经应用了logback的依赖。java

1、控制台日志信息介绍

1.1 日志级别

日志级别从高到低为:TRACE < DEBUG < INFO < WARN < ERROR < ALL < OFFgit

若是日志设置为ERROR,那么低于ERROR级别的日志将不会输出。github

若是咱们想要设置某个包的日志级别,则在pom文件中加入下面这行配置:redis

logging:
  level:
  	# 包名
    com.javatrip: warn

若是想修改Spring Boot默认级别,则将包名改成rootspring

logging:
  level:
    root: warn

1.2 控制台日志介绍

默认状况下,Spring Boot会将INFO级别的日志输出到控制台。控制台输出信息以下:数据库

日志输出内容具体含义以下:缓存

  • 时间日期:精确到毫秒
  • 日志级别:ERROR, WARN, INFO, DEBUG or TRACE
  • 进程ID
  • 分隔符:--- 标识实际日志的开始
  • 线程名:方括号括起来(可能会截断控制台输出)
  • Logger名:一般使用源代码的类名
  • 日志内容

2、日志文件输出

在实际项目中,咱们须要将日志输出为文件,以便快速定位问题。Spring Boot关于日志文件的信息能够参考官网https://docs.spring.io/spring-boot/docs/current/reference/htmlsingle/#boot-features-logging微信

Because the standard logback.xml configuration file is loaded too early, you cannot use extensions in it. You need to either use logback-spring.xml or define a logging.config property.mybatis

这句话的意思大概就是:因为标准的logback.xml配置文件加载得太早,所以您不能在其中使用扩展名。您须要使用logback-spring.xml或定义logging.config属性。

所以咱们来定义一个logback-spring.xml的文件来进行日志信息的配置。

logback-spring.xml文件定义及注释:

<?xml version="1.0" encoding="UTF-8"?>
<configuration>
    <!-- 日志文件名 -->
    <property name="LOG_FILE" value="myLog" />
    <!-- 日志文件路径 -->
    <property name="LOG_PATH" value="D://log//dev" />
    <!-- 控制台日志输出格式 -->
    <property name="LOG_PATTERN_CONSOLE" value="%d{yyyy-MM-dd HH:mm:ss} [%thread] %-5level %logger{50} --> %msg%n" />
    <!-- 文件日志输出格式 -->
    <property name="LOG_PATTERN_FILE" value="%d{yyyy-MM-dd HH:mm:ss} [%thread] %-5level %logger{50} --> %msg%n" />
    <!--- 设置控制台日志 -->
    <appender name="consoleLog" class="ch.qos.logback.core.ConsoleAppender">
        <encoder>
            <pattern>${LOG_PATTERN_CONSOLE}</pattern>
        </encoder>
    </appender>
    <!-- 设置日志文件 -->
    <appender name="fileLog" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <encoder>
            <pattern>${LOG_PATTERN_FILE}</pattern>
        </encoder>
		<!-- 总文件日志 -->
        <file>${LOG_PATH}/${LOG_FILE}.log</file>
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <!-- 天天的文件日志 -->
            <fileNamePattern>${LOG_PATH}/${LOG_FILE}-%d{yyyy-MM-dd}.log</fileNamePattern>
            <!-- 日志文件保存7天,超过7天的自动删除 -->
            <maxHistory>7</maxHistory>
        </rollingPolicy>
    </appender>

    <!-- 设置日志级别,及须要记录日志的类 -->
    <root level="INFO">
        <appender-ref ref="consoleLog" />
        <appender-ref ref="fileLog" />
    </root>
</configuration>

启动项目后,在D:\log\dev中会生产咱们的日志文件myLog.log,加入咱们系统一直运行,则在咱们的文件目录下会生成一个myLog.log文件和7个最近日志的文件myLog-某年-某月-某日.log


本文示例代码已上传至github,点个star支持一下!

Spring Boot系列教程目录

spring-boot-route(一)Controller接收参数的几种方式

spring-boot-route(二)读取配置文件的几种方式

spring-boot-route(三)实现多文件上传

spring-boot-route(四)全局异常处理

spring-boot-route(五)整合Swagger生成接口文档

spring-boot-route(六)整合JApiDocs生成接口文档

spring-boot-route(七)整合jdbcTemplate操做数据库

spring-boot-route(八)整合mybatis操做数据库

spring-boot-route(九)整合JPA操做数据库

spring-boot-route(十)多数据源切换

spring-boot-route(十一)数据库配置信息加密

spring-boot-route(十二)整合redis作为缓存

spring-boot-route(十三)整合RabbitMQ

spring-boot-route(十四)整合Kafka

spring-boot-route(十五)整合RocketMQ

spring-boot-route(十六)使用logback生产日志文件

spring-boot-route(十七)使用aop记录操做日志

spring-boot-route(十八)spring-boot-adtuator监控应用

spring-boot-route(十九)spring-boot-admin监控服务

spring-boot-route(二十)Spring Task实现简单定时任务

spring-boot-route(二十一)quartz实现动态定时任务

spring-boot-route(二十二)实现邮件发送功能

spring-boot-route(二十三)开发微信公众号

这个系列的文章都是工做中频繁用到的知识,学完这个系列,应付平常开发绰绰有余。若是还想了解其余内容,扫面下方二维码告诉我,我会进一步完善这个系列的文章!

相关文章
相关标签/搜索