日志是一个系统非常重要的一部分,我们经常需要通过查看日志来定位问题,今天我们一起来学习一下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"?>
${LOG_PATTERN_CONSOLE}${LOG_PATTERN_FILE}${LOG_PATH}/${LOG_FILE}.log${LOG_PATH}/${LOG_FILE}-%d{yyyy-MM-dd}.log7
启动项目后,在D:\log\dev
中会生产我们的日志文件myLog.log
,加入我们系统一直运行,则在我们的文件目录下会生成一个myLog.log
文件和7个最近日志的文件myLog-某年-某月-某日.log
。
此是spring-boot-route系列的第十六篇文章,这个系列的文章都比较简单,主要目的就是为了帮助初次接触Spring Boot 的同学有一个系统的认识。本文已收录至我的github,欢迎各位小伙伴star
!