工作3年啦,你竟然连Java日志体系都没闹懂?说不过去~
大家好,我是D哥
点击关注下方公众号,Java面试资料 都在这里
# 概要
# Log日志体系
# 背景/发展史
那就要从Java Log的发展历程开始说起。
log4j(作者Ceki Gülcü)出来时就等到了广泛的应用(注意这里是直接使用),是Java日志事实上的标准,并成为了Apache的项目
Apache要求把log4j并入到JDK,SUN拒绝,并在jdk1.4版本后增加了JUL(java.util.logging)
毕竟是JDK自带的,JUL也有很多人用。同时还有其他日志组件,如SimpleLog等。这时如果有人想换成其他日志组件,如log4j换成JUL,因为api完全不同,就需要改动代码。
Apache见此,开发了JCL(Jakarta Commons Logging),即commons-logging-xx.jar。它只提供一套通用的日志接口api,并不提供日志的实现。很好的设计原则嘛,依赖抽象而非实现。这样应用程序可以在运行时选择自己想要的日志实现组件。
这样看上去也挺美好的,但是log4j的作者觉得JCL不好用,自己开发出slf4j,它跟JCL类似,本身不替供日志具体实现,只对外提供接口或门面。目的就是为了替代JCL。同时,还开发出logback,一个比log4j拥有更高性能的组件,目的是为了替代log4j。
Apache参考了logback,并做了一系列优化,推出了log4j2
# 关系/依赖
JCL
JCL支持日志组件不多,不过也有很人用的,例如Spring
SLF4J
slf4j + logback
slf4j-api.jar + logback-classic.jar + logback-core.jarslf4j + log4j
slf4j-api.jar + slf4j-log4j12.jar + log4j.jarslf4j + jul
slf4j-api.jar + slf4j-jdk14.jar也可以只用slf4j无日志实现
slf4j-api.jar + slf4j-nop.jar
SLF4J的适配
你在用JCL
使用jcl-over-slf4j.jar适配你在用log4j
使用log4j-over-slf4j.jar适配你在用JUL
使用jul-to-slf4j.jar适配
很简单,就是加入jcl-over-slf4j.jar就好了。
你首先确认需要统一日志的模块、框架是使用哪个日志组件的,然后再找到sfl4j的适配器。
记得去掉无用的日志实现组件,只保留你要用的。
# 常见问题
Failed to load class org.slf4j.impl.StaticLoggerBinder
Multiple bindings
# 代码规范
【强制】应用中不可直接使用日志系统(Log4j、Logback)中的 API,而应依赖使用日志框架 SLF4J 中的 API,使用门面模式的日志框架,有利于维护和各个类的日志处理方式统一。
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
private static final Logger logger = LoggerFactory.getLogger(Abc.class);
# 总结
有不少同学问D哥,大厂面试官到底喜欢问什么?想进大厂镀金。因此,D哥特意邀请了华为、腾讯、阿里的朋友进群,与大家一起交流经验,增长技术。
有兴趣入群的同学,可长按扫描下方二维码,一定要备注:城市+昵称+技术方向,根据格式备注,可更快被通过且邀请进群。
▲长按扫描