zoukankan      html  css  js  c++  java
  • spring-boot-route(十六)使用logback生产日志文件

    日志是一个系统非常重要的一部分,我们经常需要通过查看日志来定位问题,今天我们一起来学习一下Spring Boot的日志系统。有很多同学习惯性的在生产代码中使用System.out来输出日志,这是不推荐的一种做法,因为System.out是一个同步操作,会在一定程度上影响系统性能,而Logger是一个异步操作。

    Spring Boot默认的日志系统是logback,当然我们并不需要去引用logback的依赖,因为在spring-boot-starter中已经应用了logback的依赖。

    一、控制台日志信息介绍

    1.1 日志级别

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

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

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

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

    如果想修改Spring Boot默认级别,则将包名改为root

    logging:
      level:
        root: warn
    

    1.2 控制台日志介绍

    默认情况下,Spring Boot会将INFO级别的日志输出到控制台。控制台输出信息如下:

    日志输出内容具体含义如下:

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

    二、日志文件输出

    在实际项目中,我们需要将日志输出为文件,以便快速定位问题。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.

    这句话的意思大概就是:由于标准的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:logdev中会生产我们的日志文件myLog.log,加入我们系统一直运行,则在我们的文件目录下会生成一个myLog.log文件和7个最近日志的文件myLog-某年-某月-某日.log

    此是spring-boot-route系列的第十六篇文章,这个系列的文章都比较简单,主要目的就是为了帮助初次接触Spring Boot 的同学有一个系统的认识。本文已收录至我的github,欢迎各位小伙伴star

    githubhttps://github.com/binzh303/spring-boot-route

    点关注、不迷路

    如果觉得文章不错,欢迎关注点赞收藏,你们的支持是我创作的动力,感谢大家。

    如果文章写的有问题,请不要吝啬,欢迎留言指出,我会及时核查修改。

    如果你还想更加深入的了解我,可以微信搜索「Java旅途」进行关注。回复「1024」即可获得学习视频及精美电子书。每天7:30准时推送技术文章,让你的上班路不在孤独,而且每月还有送书活动,助你提升硬实力!

  • 相关阅读:
    关于Markdown
    20. 有效的括号(栈)
    数组队列
    MySql编码、卸载、启动问题
    循环队列
    链表实现与时间复杂度分析
    栈的应用和基本实现
    使用链表实现栈
    封装动态数组类Array
    Android平台的开发环境的发展演变
  • 原文地址:https://www.cnblogs.com/zhixie/p/13819869.html
Copyright © 2011-2022 走看看