日志是一个系统很是重要的一部分,咱们常常须要经过查看日志来定位问题,今天咱们一块儿来学习一下Spring Boot的日志系统。有不少同窗习惯性的在生产代码中使用System.out来输出日志,这是不推荐的一种作法,由于System.out是一个同步操做,会在必定程度上影响系统性能,而Logger是一个异步操做。html
Spring Boot默认的日志系统是logback
,固然咱们并不须要去引用logback
的依赖,由于在spring-boot-starter
中已经应用了logback
的依赖。java
日志级别从高到低为:TRACE
< DEBUG
< INFO
< WARN
< ERROR
< ALL
< OFF
。git
若是日志设置为ERROR
,那么低于ERROR
级别的日志将不会输出。github
若是咱们想要设置某个包的日志级别,则在pom文件中加入下面这行配置:spring
logging: level: # 包名 com.javatrip: warn
若是想修改Spring Boot默认级别,则将包名改成root
。微信
logging: level: root: warn
默认状况下,Spring Boot会将INFO
级别的日志输出到控制台。控制台输出信息以下:app
日志输出内容具体含义以下:异步
---
标识实际日志的开始在实际项目中,咱们须要将日志输出为文件,以便快速定位问题。Spring Boot关于日志文件的信息能够参考官网https://docs.spring.io/spring-boot/docs/current/reference/htmlsingle/#boot-features-logging
。spring-boot
Because the standardlogback.xml
configuration file is loaded too early, you cannot use extensions in it. You need to either uselogback-spring.xml
or define alogging.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:\log\dev
中会生产咱们的日志文件myLog.log
,加入咱们系统一直运行,则在咱们的文件目录下会生成一个myLog.log
文件和7个最近日志的文件myLog-某年-某月-某日.log
。
此是spring-boot-route系列的第十六篇文章,这个系列的文章都比较简单,主要目的就是为了帮助初次接触Spring Boot 的同窗有一个系统的认识。本文已收录至个人github,欢迎各位小伙伴star
!
github:https://github.com/binzh303/s...
若是以为文章不错,欢迎关注、点赞、收藏,大家的支持是我创做的动力,感谢你们。
若是文章写的有问题,请不要吝啬,欢迎留言指出,我会及时核查修改。
若是你还想更加深刻的了解我,能够微信搜索「Java旅途」进行关注。回复「1024」便可得到学习视频及精美电子书。天天7:30准时推送技术文章,让你的上班路不在孤独,并且每个月还有送书活动,助你提高硬实力!