SLF4J是一个用于日志系统的简单Facade,允许最终用户在部署其应用时使用其所希望的日志系统。
SLF4J库类似于Apache Commons-Logging,但Apache Commons-Logging采用的是动态绑定机制,使用ClassLoader寻找和载入底层的日志库,而在OSGI中,不同的插件使用自己的ClassLoader,OSGI的这种机制保证了插件互相独立,然而却使得Apache Commons-Logging无法在OSGI的环境下工作了。SLF4J却没有这个问题,它是如何做到的呢?
一个简单的例子:
package chapters.introduction; import org.slf4j.Logger; import org.slf4j.LoggerFactory; public class HelloWorld1 { public static void main(String[] args) { Logger logger = LoggerFactory.getLogger("chapters.introduction.HelloWorld1"); logger.debug("Hello world."); } }
SLF4J与日志系统的绑定过程是在getLogger方法中完成的!下面介绍整个绑定过程。
通过上图大家可以发现整个静态绑定机制的核心是通过查找类路径下面的org/slf4j/impl/StaticLoggerBinder.class,所以类路径下只能有一个这个类。看到这里大家可能会问了,这个类的包名是org.slf4j.impl,找这个类如何与其他的日志系统连接呢?呵呵,这个很简单,其实slf4j的发布包中包含了为多种日志系统写好的绑定代理,每个日志系统都写好了一个独立的StaticLoggerBinder,由这个类调用相关日志系统的对象!
下图是slf4j发布包中的为各个日志系统写好的绑定代理。
为什么没有logback的绑定代理?呵呵,因为logback中已经内置了slf4j的绑定代理。
