Java日志系统

日志,源于log,有航海日志的意思。指记录海员记录每天的行程,生活及发生的事件。在软件开发领域,用来监控代码中变量变化,跟踪代码运行的轨迹,在开发环境中担当调试器作用,向控制台或文件输出信息。

 

几乎所有的软件开发语言(平台)都有自己的日志系统,java,.net,ruby,php等。在java领域,存在大量的日志组件,open-open收录了21个日志组件。

从功能上讲,这些可以分为三类,一是日志工具类,它实现了日志的记录,格式化和级别的划分,代表为logback,simplelog。二是日志系统,提供了完整的框架功能并实现了日志记录。代表为jul(jdk提供的日志框架),log4j(apache开源项目)。三是抽象整合类,它提供了一组接口,完成日志功能,通过包装其他日志工具或系统来工作jcl(apache开源组件),slf4j。

 

从历史上讲,log4j出现最早,Ceki Gülcü是其创造者。自java1.4开始,jdk提供了java.util.logging类库,提供了一个完整的日志框架,在设计上要比log4j要更清晰。这个时候,除此之外,还有一些其他日志组件,java领域从来不缺少轮子,总是有人在发明轮子,轮子多了,就会产生混乱,就会有人站出来,要一统江湖,于是,jcl,apache一个开源的日志组件诞生了,它提供了一组日志系统的接口,通过对log4j,jul和simplelog进行包装,提供日志功能。这样,开发的时候,只需要使用jcl,通过配置,灵活选择底层实现。这样,对于开发人员来说,开发更简单了些。看起来一切太平了,可Ceki Gülcü认为,应该有一个更好的日志框架。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,一是它可以整合其他遗留日志组件,二是其提供的抽象层,为将来的开发提供了灵活性。

 

参考资料:

1.IBM developerworks对log4j的介绍。 链接

2.Java开源日志组件列表。链接

3.Slf4j官方网站。链接

4.Logback官方网站。链接

5.Log4j官方网站。链接

6.Jcl官方网站。链接

7.Sun官方网站。链接

8.一个jcl的中文说明。链接

你可能感兴趣的:(log4j,logback,日志,slf4j,jul,jcl)