资源预览内容
第1页 / 共3页
第2页 / 共3页
第3页 / 共3页
亲,该文档总共3页全部预览完了,如果喜欢就下载吧!
资源描述
Java日志系统研究日志,源于log,有航海日志的意思。指记录海员记录每天的行程,生活及发生的事件。在软件开发领域,用来监控代码中变量变化,跟踪代码运行的轨迹,在开发环境中担当调试器作用,向控制台或文件输出信息。几乎所有的软件开发语言(平台)都有自己的日志系统,java,.net,ruby,php等。在java领域,存在大量的日志组件,open-open收录了21个日志组件。从功能上讲,这些可以分为三类,一是日志工具类,它实现了日志的记录,格式化和级别的划分,代表为logback,simplelog。二是日志系统,提供了完整的框架功能并实现了日志记录。代表为jul(jdk提供的日志框架),log4j(apache开源项目)。三是抽象整合类,它提供了一组接口,完成日志功能,通过包装其他日志工具或系统来工作jcl(apache开源组件),slf4j。从历史上讲,log4j出现最早,Ceki Glc是其创造者。自java1.4开始,jdk提供了java.util.logging类库,提供了一个完整的日志框架,在设计上要比log4j要更清晰。这个时候,除此之外,还有一些其他日志组件,java领域从来不缺少轮子,总是有人在发明轮子,轮子多了,就会产生混乱,就会有人站出来,要一统江湖,于是,jcl,apache一个开源的日志组件诞生了,它提供了一组日志系统的接口,通过对log4j,jul和simplelog进行包装,提供日志功能。这样,开发的时候,只需要使用jcl,通过配置,灵活选择底层实现。这样,对于开发人员来说,开发更简单了些。看起来一切太平了,可Ceki Glc认为,应该有一个更好的日志框架。log4j经过这么久的发展,已经成为了一个巨人,亦伤痕累累,从外面看,经典,庄重,强壮,从内部看,却有着一根根的飞线(ThinkPad),充满了代码的坏味道。或许他没有勇气来改造这个巨人,离开也许是最好的选择,于是,出来,创建了slf4j,来取代jcl,创建了logback,来取代log4j。目前,log4j和jul应用最为广泛,slf4j作为新兴的抽象层,整合logback,以其简洁,快速,正被越来越多的顶级项目使用。代表日志组件简要介绍。Log4j,历史悠久,应用广泛,被移植到多种语言及平台,功能强大,在众多的日志框架中,仍占据着主导地位。Jul,jdk提供的日志框架,设计精良,和jdk紧密结合,控制灵活,使用简单。Jcl,提供了日志的抽象层,可以整合多种实现。但有classloader问题。Slf4j,提供了jcl的超集,避免了classloader问题。Logback,可靠,通用,快速,灵活的java日志工具(官方描述)。项目选择思考。如果是单一的项目,如桌面应用,采用jul,免配置,控制灵活。如果是web开发,宜采用log4j,因为系统已经有了很多的配置文件,不在乎多一个,而且log4j可以脱离任何组件,不像jul,和jvm紧密结合在一起。如果是多项目整合开发,宜采用slf4j,一是它可以整合其他遗留日志组件,二是其提供的抽象层,为将来的开发提供了灵活性。参考资料:1IBM developerworks对log4j的介绍。 链接2Java开源日志组件列表。链接3Slf4j官方网站。链接4Logback官方网站。链接5Log4j官方网站。链接6Jcl官方网站。链接7Sun官方网站。链接8一个jcl的中文说明。链接
网站客服QQ:2055934822
金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号