本编文章主要介绍:
如何引入日志?
日志输出格式以及输出方式如何配置?
代码中如何使用?
Spring Boot在所有内部日志中使用Commons Logging,但是默认配置也提供了对常用日志的支持,如:Java Util Logging,Log4J, Log4J2和Logback。每种Logger都可以通过配置使用控制台或者文件输出日志内容。
默认情况下,Spring Boot会用Logback来记录日志,并用INFO级别输出到控制台
SLF4J——Simple Logging Facade For Java,它是一个针对于各类Java日志框架的统一Facade抽象。Java日志框架众多——常用的有java.util.logging, log4j, logback,commons-logging, Spring框架使用的是Jakarta Commons Logging API (JCL)。而SLF4J定义了统一的日志抽象接口,而真正的日志实现则是在运行时决定的——它提供了各类日志框架的binding。
Logback是log4j框架的作者开发的新一代日志框架,它效率更高、能够适应诸多的运行环境,同时天然支持SLF4J。
1.如何引入日志
org.springframework.boot
spring-boot-starter
只需要引入 spring-boot -starter-logging 即可如果已经引入spring-boot-starter则不需要再引入logging因为其中已经包含logging引用。如下图所示
[图片上传失败...(image-66dc51-1522074332943)]
2.日志输出格式以及输出方式如何配置
创建一个logback.xml文件
spring-boot-log
log/spring-boot-log-info.log
log/spring-boot-log-info-%d{yyyy-MM-dd}.%i.log
128MB
30
true
%d{yyyy-MM-dd HH:mm:ss.SSS} %-5level %logger Line:%-3L - %msg%n
utf-8
info
ACCEPT
DENY
log/spring-boot-log-error.log
log/spring-boot-log-error-%d{yyyy-MM-dd}.%i.log
2MB
180
true
%d{yyyy-MM-dd HH:mm:ss.SSS} %-5level %logger Line:%-3L - %msg%n
utf-8
ERROR
ACCEPT
DENY
%d{yyyy-MM-dd HH:mm:ss.SSS} %-5level %logger Line:%-3L - %msg%n
utf-8
INFO
下面对节点属性做一个简单的介绍
根节点
包含的属性
scan:当此属性设置为true时,配置文件如果发生改变,将会被重新加载,默认值为true。
scanPeriod:设置监测配置文件是否有修改的时间间隔,如果没有给出时间单位,默认单位是毫秒。当scan为true时,此属性生效。默认的时间间隔为1分钟。
debug:当此属性设置为true时,将打印出logback内部日志信息,实时查看logback运行状态。默认值为false。
根节点
的子节点:
下面一共有2个属性,3个子节点,分别是:
属性一:设置上下文名称
每个logger都关联到logger上下文,默认上下文名称为“default”。但可以使用设置成其他名字,用于区分不同应用程序的记录。一旦设置,不能修改,可以通过%contextName来打印日志上下文名称。
属性二:设置变量
用来定义变量值的标签, 有两个属性,name和value;其中name的值是变量的名称,value的值时变量定义的值。通过定义的值会被插入到logger上下文中。定义变量后,可以使“${}”来使用变量。
子节点一
appender用来格式化日志输出节点,有俩个属性name和class,class用来指定哪种输出策略,常用就是控制台输出策略和文件输出策略。
控制台
%d{yyyy-MM-dd HH:mm:ss.SSS} %-5level %logger Line:%-3L - %msg%n
utf-8
INFO
ThresholdFilter为系统定义的拦截器,例如我们用ThresholdFilter来过滤掉ERROR级别以下的日志不输出到文件中。如果不用记得注释掉,不然你控制台会发现没日志
输出到文件RollingFileAppender
另一种常见的日志输出到文件,随着应用的运行时间越来越长,日志也会增长的越来越多,将他们输出到同一个文件并非一个好办法。RollingFileAppender用于切分文件日志:
log/spring-boot-log-info.log
log/spring-boot-log-info-%d{yyyy-MM-dd}.%i.log
128MB
30
true
%d{yyyy-MM-dd HH:mm:ss.SSS} %-5level %logger Line:%-3L - %msg%n
utf-8
info
ACCEPT
DENY
子节点二
root节点是必选节点,用来指定最基础的日志输出级别,只有一个level属性。
level:用来设置打印级别,大小写无关:TRACE, DEBUG, INFO, WARN, ERROR, ALL 和 OFF,不能设置为INHERITED或者同义词NULL。
默认是DEBUG。
可以包含零个或多个元素,标识这个appender将会添加到这个loger。
子节点三
name:用来指定受此loger约束的某一个包或者具体的某一个类。
level:用来设置打印级别,大小写无关:TRACE, DEBUG, INFO, WARN, ERROR, ALL 和 OFF,还有一个特俗值INHERITED或者同义词NULL,代表强制执行上级的级别。如果未设置此属性,那么当前loger将会继承上级的级别。
3代码中如何使用
使用的话只需要在使用的类中加入
private Logger logger = LoggerFactory.getLogger(this.getClass());
logger.info("index");
输出日志既可运行项目发现
已经生成了这两个log文件
4.对于Logback的简单说明:
1、Logback为取代log4j而生
Logback是由log4j创始人Ceki Gülcü设计的又一个开源日志组件。logback当前分成三个模块:logback-core,logback- classic和logback-access。
2、Logback的核心对象:Logger、Appender、Layout
Logback主要建立于Logger、Appender 和 Layout 这三个类之上。
1 : Logger:日志的记录器,把它关联到应用的对应的context上后,主要用于存放日志对象,也可以定义日志类型、级别。Logger对象一般多定义为静态常量,如:
2: Appender:用于指定日志输出的目的地,目的地可以是控制台,文件,远程套接字,Mysql,PostreSQL,Oracle,和其他数据库
3:layout:负责把时间转换成字符串,格式话的日志信息的输出.
3 Level的幼小的级别,Logger可以分配级别,级别包括:trace,Debug,Info,Warn,和Error,定义于
ch.qos.logback.classic.Level类,程序会打印高于或者等于所设置级别的izhi,设置级别的日志等级越高,打印出来的日
志就越少,如果设置级别为info的日志信息可以被输出,小于该级别的如DEBUG不会被输出,为确保所有logger都能最
终继承一个级别,因此根的logger也总是有级别,一般而言,这个级别是DEBUG
4:三值逻辑
在logback的过滤器基于三值逻辑,允许把他们组装成为链条,从而组装成任意符合过滤策略,过滤器很大的程度上受到了 iptables的启发,这里所谓三值逻辑是说:
如果返回Deny, 那么记录时间立即被抛弃,不在经过剩余的过滤器
如果返回Neutral,那么有序列表里的下一个过滤器会接着处理记录事件
如果返回Accept,那么记录时间被立即处理,不再经过剩余的过滤器
5 Filter 过滤
logback-classic 提供两种类型的过滤:
5.1: 常规过滤器
5.2:TuroboFilter过滤器
参考文章:http://tengj.top/2017/04/05/springboot7/
文章链接:http://www.haha174.top/article/details/252573
源码链接:https://github.com/haha174/boot.git
推荐一篇文章:http://mp.weixin.qq.com/s?__biz=MzA3MTU0MDg2OQ==&mid=2247483731&idx=1&sn=35332c0e058d02cacbacd30707db9a5a&chksm=9f2d48b9a85ac1af4dc84ee7fccdecd1be010f82f13a40c78516cb488965b24e8d427e93fb23&mpshare=1&scene=23&srcid=1015ORKoX6SDjipznhzALSvc#rd
欢迎关注,更多福利