概述
1. Commom-logging(接口)
Common-logging是Apache提供的一个通用的日志接口,它是Java中广泛使用的日志门面。它通过动态查找的机制,在程序运行时自动找出真正使用的日志库。
Common-logging一直运行的很好,但是当它碰到OSGI时,它不能工作了。原因是Apache Common-logging使用Classloader寻找和载入底层的日志库,而OSGI中,不同的插件使用自己的ClassLoader。
解决之道是使用新的日志门面Slf4j。
2. Slf4j(接口)
类似于Apache Common-Logging,是对不同日志框架提供的一个门面封装,可以部署的时候不修改任何配置即可接入一种日志实现方案。但是,他在编译时静态绑定真正的Log库。使用SLF4J时,如果你需要使用某一种日志实现,那么你必须选择正确的SLF4J的jar包的集合(各种桥接包)。
3. Log4j(实现)
Apache的一个开放源代码项目,通过使用Log4j,我们可以控制日志信息输送的目的地是控制台、文件、GUI组件、甚至是套接口服务 器、NT的事件记录器、UNIX Syslog守护进程等;用户也可以控制每一条日志的输出格式;通过定义每一条日志信息的级别,用户能够更加细致地控制日志的生成过程。这些可以通过一个 配置文件来灵活地进行配置,而不需要修改程序代码。
4. Logback(实现)
Logback是由log4j创始人设计的又一个开源日记组件。logback当前分成三个模块:logback-core,logback- classic和logback-access。logback-core是其它两个模块的基础模块。logback-classic是log4j的一个 改良版本。此外logback-classic完整实现SLF4J API使你可以很方便地更换成其它日记系统如log4j或JDK14 Logging。logback-access访问模块与Servlet容器集成提供通过Http来访问日记的功能。
5. Log4j与Logback的比较
LogBack作为一个通用可靠、快速灵活的日志框架,将作为Log4j的替代和SLF4J组成新的日志系统的完整实现。LOGBack声称具有极佳的性能,“ 某些关键操作,比如判定是否记录一条日志语句的操作,其性能得到了显著的提高。这个操作在LogBack中需要3纳秒,而在Log4J中则需要30纳秒。 LogBack创建记录器(logger)的速度也更快:13微秒,而在Log4J中需要23微秒。更重要的是,它获取已存在的记录器只需94纳秒,而 Log4J需要2234纳秒,时间减少到了1/23。跟JUL相比的性能提高也是显著的”。 另外,LOGBack的所有文档是全面免费提供的,不象Log4J那样只提供部分免费文档而需要用户去购买付费文档。
6. 最终总结
最佳组合为slf4j与logback
最后
以上就是开朗季节为你收集整理的Java日志管理:common-logging、slf4j、log4j、logback的关系1. Commom-logging(接口)2. Slf4j(接口)3. Log4j(实现)4. Logback(实现)5. Log4j与Logback的比较6. 最终总结的全部内容,希望文章能够帮你解决Java日志管理:common-logging、slf4j、log4j、logback的关系1. Commom-logging(接口)2. Slf4j(接口)3. Log4j(实现)4. Logback(实现)5. Log4j与Logback的比较6. 最终总结所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
发表评论 取消回复