Java日志管理:common-logging、slf4j、log4j、logback的关系

1. Commom-logging(接口)

Common-loggingApache提供的一个通用的日志接口,它是Java中广泛使用的日志门面。它通过动态查找的机制,在程序运行时自动找出真正使用的日志库。

Common-logging一直运行的很好,但是当它碰到OSGI时,它不能工作了。原因是Apache Common-logging使用Classloader寻找和载入底层的日志库,而OSGI中,不同的插件使用自己的ClassLoader

解决之道是使用新的日志门面Slf4j

2. Slf4j(接口)

类似于Apache Common-Logging,是对不同日志框架提供的一个门面封装,可以部署的时候不修改任何配置即可接入一种日志实现方案。但是,他在编译时静态绑定真正的Log库。使用SLF4J时,如果你需要使用某一种日志实现,那么你必须选择正确的SLF4Jjar包的集合(各种桥接包)。

3. Log4j(实现)

Apache的一个开放源代码项目,通过使用Log4j,我们可以控制日志信息输送的目的地是控制台、文件、GUI组件、甚至是套接口服务 器、NT的事件记录器、UNIX Syslog守护进程等;用户也可以控制每一条日志的输出格式;通过定义每一条日志信息的级别,用户能够更加细致地控制日志的生成过程。这些可以通过一个 配置文件来灵活地进行配置,而不需要修改程序代码。

4. Logback(实现)

Logback是由log4j创始人设计的又一个开源日记组件。logback当前分成三个模块:logback-core,logback- classiclogback-accesslogback-core是其它两个模块的基础模块。logback-classiclog4j的一个 改良版本。此外logback-classic完整实现SLF4J API使你可以很方便地更换成其它日记系统如log4jJDK14 Logginglogback-access访问模块与Servlet容器集成提供通过Http来访问日记的功能。

 

5. Log4jLogback的比较

LogBack作为一个通用可靠、快速灵活的日志框架,将作为Log4j的替代和SLF4J组成新的日志系统的完整实现。LOGBack声称具有极佳的性能,“ 某些关键操作,比如判定是否记录一条日志语句的操作,其性能得到了显著的提高。这个操作在LogBack中需要3纳秒,而在Log4J中则需要30纳秒。 LogBack创建记录器(logger)的速度也更快:13微秒,而在Log4J中需要23微秒。更重要的是,它获取已存在的记录器只需94纳秒,而 Log4J需要2234纳秒,时间减少到了1/23。跟JUL相比的性能提高也是显著的”。 另外,LOGBack的所有文档是全面免费提供的,不象Log4J那样只提供部分免费文档而需要用户去购买付费文档。 

6. 最终总结

最佳组合为slf4jlogback

 

你可能感兴趣的:(JavaWeb)