SpringBoot
是为了简化Spring
应用的建立、运行、调试、部署等一系列问题而诞生的产物,自动装配的特性让咱们能够更好的关注业务自己而不是外部的XML配置,咱们只需遵循规范,引入相关的依赖就能够轻易的搭建出一个 WEB 工程
Spring Boot
内部采用的是 Commons Logging
进行日志记录,但在底层为 Java Util Logging
、Log4J2
、Logback
等日志框架提供了默认配置 。html
Java 虽然有不少可用的日志框架,但请不要担忧,通常来讲,使用SpringBoot
默认的Logback
就能够了。
<!-- more -->java
SpringBoot
的默认输出的日志格式以下:
2014-03-05 10:57:51.112 INFO 45469 --- [ main] org.apache.catalina.core.StandardEngine : Starting Servlet Engine: Apache Tomcat/7.0.52 2014-03-05 10:57:51.253 INFO 45469 --- [ost-startStop-1] o.a.c.c.C.[Tomcat].[localhost].[/] : Initializing Spring embedded WebApplicationContext 2014-03-05 10:57:51.253 INFO 45469 --- [ost-startStop-1] o.s.web.context.ContextLoader : Root WebApplicationContext: initialization completed in 1358 ms 2014-03-05 10:57:51.698 INFO 45469 --- [ost-startStop-1] o.s.b.c.e.ServletRegistrationBean : Mapping servlet: 'dispatcherServlet' to [/] 2014-03-05 10:57:51.702 INFO 45469 --- [ost-startStop-1] o.s.b.c.embedded.FilterRegistrationBean : Mapping filter: 'hiddenHttpMethodFilter' to: [/*]
输出以下元素:
Logback
是没有 FATAL
级别的日志,它将被映射到 ERROR
web
---
来标识日志开始部分SpringBoot
默认为咱们输出的日志级别为 INFO
、WARN
、ERROR
,如须要输出更多日志的时候,能够经过如下方式开启spring
java -jar app.jar --debug=true
, 这种命令会被 SpringBoot
解析,且优先级最高application.properties
配置 debug=true
便可。该配置只对 嵌入式容器、Spring、Hibernate生效,咱们本身的项目想要输出 DEBUG
须要额外配置(配置规则:logging.level.<logger-name>=<level>
) 日志输出级别配置
logging.level.root = WARN logging.level.org.springframework.web = DEBUG logging.level.org.hibernate = ERROR #好比 mybatis sql日志 logging.level.org.mybatis = INFO logging.level.mapper所在的包 = DEBUG
日志输出格式配置
若是终端支持 ANSI
,默认状况下会给日志上个色,提升可读性,能够在配置文件中设置 spring.output.ansi.enabled
来改变默认值sql
ANSI
颜色的输出。ANSI
着色功能是否可用。ANSI
颜色的输出。Level | Color |
---|---|
WARN |
Yellow |
FATAL 、ERROR |
Red |
INFO 、DEBUG 、TRACE |
Green |
若是想修改日志默认色值,能够经过使用 %clr
关键字转换。好比想使文本变为黄色 %clr(%d{yyyy-MM-dd HH:mm:ss.SSS}){yellow}
。目前支持的颜色有(blue
、cyan
、faint
、green
、magenta
、red
、yellow
)apache
默认状况下,SpringBoot
仅将日志输出到控制台,不会写入到日志文件中去。若是除了控制台输出以外还想写日志文件,则须要在application.properties
设置logging.file
或 logging.path
属性。微信
spring.log
写入到指定的 文件夹 中,如(/var/log
)日志文件在达到 10MB
时进行切割,产生一个新的日志文件(如:spring.1.log、spring.2.log
),新的日志依旧输出到 spring.log
中去,默认状况下会记录 ERROR
、WARN
、INFO
级别消息。mybatis
因为日志在 ApplicationContext
以前就初始化好了,因此 SpringBoot
为咱们提供了 logging.config
属性,方便咱们配置自定义日志文件。默认状况它会根据日志的依赖自动加载。app
Logging System | Customization |
---|---|
JDK (Java Util Logging) |
logging.properties |
Log4j2 、ERROR |
log4j2-spring.xml 或 log4j2.xml |
Logback |
logback-spring.xml、logback-spring.groovy、logback.xml、logback.groovy |
该扩展配置仅适用 logback-spring.xml
或者设置 logging.config
属性的文件,由于 logback.xml
加载过早,所以没法获取 SpringBoot
的一些扩展属性框架
使用扩展属性 springProfile
与 springProperty
让你的 logback-spring.xml
配置显得更有逼格,当别人还在苦苦挣扎弄logback-{profile}.xml的时候 你一个文件就搞定了...
<springProfile>
标签使咱们让配置文件更加灵活,它能够选择性的包含或排除部分配置。
<springProfile name="dev"> <!-- 开发环境时激活 --> </springProfile> <springProfile name="dev,test"> <!-- 开发,测试的时候激活--> </springProfile> <springProfile name="!prod"> <!-- 当 "生产" 环境时,该配置不激活--> </springProfile>
<!-- 开发环境日志级别为DEBUG/而且开发环境不写日志文件 --> <springProfile name="dev"> <root level="DEBUG"> <appender-ref ref="STDOUT"/> </root> </springProfile> <!-- 测试环境日志级别为INFO/而且记录日志文件 --> <springProfile name="test"> <root level="INFO"> <appender-ref ref="FILE"/> <appender-ref ref="STDOUT"/> </root> </springProfile>
<springProperty>
标签可让咱们在 Logback 中使用 Spring Environment 中的属性。若是想在logback-spring.xml
中回读 application.properties
配置的值时,这是一个很是好的解决方案
<!-- 读取 spring.application.name 属性来生成日志文件名 scope:做用域 name:在 logback-spring.xml 使用的键 source:application.properties 文件中的键 defaultValue:默认值 --> <springProperty scope="context" name="logName" source="spring.application.name" defaultValue="myapp.log"/> <appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender"> <file>logs/${logName}.log</file> </appender>
目前不少大佬都写过关于 SpringBoot
的教程了,若有雷同,请多多包涵,本教程基于最新的 spring-boot-starter-parent:2.0.1.RELEASE
编写,包括新版本的特性都会一块儿介绍...
battcn