首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

让人头大的slf4j和log4j2

前言

一如既往的上班,一如既往的打开IDEA,一如既往的写下了这样的一行代码:

等等,写了这么久了,只知道这样可以很方便的使用log对象记录日志,那这到底是如何记录的呢?那么今天就来对这行代码背后使用的Slf4j和Log4j2一探究竟。

关于Slf4j和Log4j2

说起Slf4j和Log4j2,我们都知道这个是记录日志的,但是在Java的世界中,记录日志的框架那么多,那么这么多日志框架中,我们是如何相中Slf4j和Log4j2的?Slf4j和Log4j2和又是什么关系呢?好的,收起我们的疑问,你将在这篇文章中,一扫你的疑惑,满足你对Slf4j和Log4j2的一切想象。

首先,你要知道,Slf4j是一个日志框架,它是对所有日志框架制定的一种规范、标准、接口,并不是一个框架的具体的实现,因为接口并不能独立使用,它需要和具体的日志框架来配合使用;

其次,你要知道,Log4j2是一个日志实现,它是一种记录日志的具体实现;在Java中具体的日志实现有好多中,比如Log4j、Log4j2、Slf4j、JDKLog、Logback等等;

最后,你要知道,框架和实现的这种搭配使用方式,是为了以后如果项目对日志有其它要求而需要更换日志框架时可以不改动代码,只需要把依赖的jar包换掉就可以了。

在上面提到的日志框架中,以Slf4j和Log4j2的使用组合最为常见,但是我们知道Log4j目前已经停止更新了。Apache推出了新的Log4j2来代替Log4j,Log4j2是对Log4j的升级,与其前身Log4j相比有了显着的改进,并提供了许多Logback可用的改进,同时解决了Logback体系结构中的一些固有问题。因此,Slf4j和Log4j2应该是未来的大势所趋。

与Spring Boot集成

在普通的Maven项目中,需要使用Slf4j和Log4j2时,添加以下Maven依赖即可:

平时工作中使用Spring Boot比较多,所以这里着重总结一下Spring Boot与log4j2的集成。Spring Boot默认使用,但相比较而言,log4j2在性能上面会更好。log4j2在使用方面与log4j基本上没什么区别,比较大的区别是log4j2不再支持properties配置文件,支持xml、json格式的文件。

Log4j2配置说明

Log4j2的与Spring Boot的集成和使用都没有什么难点,而对于Log4j2的配置来说,则是整个的精华所在,也是整个的难点所在。所以这里有必要对Log4j2的配置进行详细的总结说明。

Log4j2日志有以下日志级别,从小到大依次为:、、、和,级别越大,输出的日志信息越少。接下来说说配置文件的结构:

根节点Configuration有两个属性:和:

:用来指定log4j本身的打印日志的级别;

:用于指定log4j2自动重新配置的监测间隔时间,单位是s,最小是5s。

节点说明:

:一般用来做属性定义;

:可以理解为一个管道,定义了日志内容的输出位置:

:指定Appender的名字;

:指定输出日志的目的文件带全路径的文件名;

:输出格式,不设置默认为:%m%n;

:配置日志事件能否被输出。过滤条件有三个值:ACCEPT(接受),DENY(拒绝),NEUTRAL(中立);

:输出格式,不设置默认为:%m%n;

:指定滚动日志的策略,就是什么时候进行新建日志文件输出日志;

:配置Strategy以控制日志如何(How)进行滚动。

:指定Appender的名字;

:指定输出日志的目的文件带全路径的文件名;

:输出格式,不设置默认为:%m%n;

:配置日志事件能否被输出。过滤条件有三个值:ACCEPT(接受),DENY(拒绝),NEUTRAL(中立);

:指定Appender的名字;

:SYSTEM_OUT或SYSTEM_ERR,一般只设置默认:SYSTEM_OUT;

:输出格式,不设置默认为:%m%n;

:配置日志事件能否被输出。过滤条件有三个值:ACCEPT(接受),DENY(拒绝),NEUTRAL(中立);

:用来定义输出到控制台Appender;

:用来定义输出到指定位置的文件Appender;

:用来定义超过指定大小自动删除旧的创建新文件Appender;

:简单说Logger就是一个路由器,指定类、包中的日志信息流向哪个Appender,以及控制他们的日志级别;

:属性;用来指定日志输出级别;

:属性;用来指定该Logger所适用的类或者类所在的包全路径,继承自Root节点;

:Logger的子节点,用来指定该日志输出到哪个Appender;如果没有指定,就会默认继承自Root;如果指定了,那么会在指定的这个Appender和Root的Appender中都会输出,此时我们可以设置Logger的additivity="false"只在自定义的Appender中进行输出。

:属性;用来指定日志输出级别;

:的子节点,用来指定该日志输出到哪个。

:必须要配置;用来指定项目的根日志,如果没有单独指定Logger,那么就会默认使用该Root日志输出;

:用来单独指定日志的形式,比如要为指定包下的class指定不同的日志级别等。

上面说到的一般常用的有以下三种:

:输出指定日志级别范围之内的日志;

:在指定时间范围内才会输出日志;

:输出符合特定日志级别及其以上级别的日志。

上面说到的一般常用的有以下三种:

:根据日志文件的大小进行滚动;单位有:KB,MB,GB;

:使用Cron表达式进行日志滚动,很灵活;

:这个配置需要和filePattern结合使用,注意filePattern中配置的文件重命名规则。滚动策略依赖于filePattern中配置的最具体的时间单位,根据最具体的时间单位进行滚动。这种方式比较简洁。

使用示例

为了方便大家参考学习,提供一个样例配置文件:

总结

如果每天学习一个知识点,那么一年就是365个,加油吧,少年。

  • 发表于:
  • 原文链接https://kuaibao.qq.com/s/20201027A01DR800?refer=cp_1026
  • 腾讯「腾讯云开发者社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。
  • 如有侵权,请联系 cloudcommunity@tencent.com 删除。

扫码

添加站长 进交流群

领取专属 10元无门槛券

私享最新 技术干货

扫码加入开发者社群
领券